updateUser()
Updates a User
.
- Name
userId
- Type
string
- Description
The ID of the user to update.
- Name
externalId?
- Type
string
- Description
The ID of the user as used in your external systems or your previous authentication solution. Must be unique across your instance.
- Name
firstName?
- Type
string
- Description
The user's first name.
- Name
lastName?
- Type
string
- Description
The user's last name.
- Name
primaryEmailAddressID?
- Type
string
- Description
The ID of the email address to set as primary. It must be verified, and present on the current user.
- Name
notifyPrimaryEmailAddressChanged?
- Type
boolean
- Description
If set to
true
, the user will be notified that their primary email address has changed. By default, no notification is sent. Defaults tofalse
.
- Name
primaryPhoneNumberID?
- Type
string
- Description
The ID of the phone number to set as primary. It must be verified, and present on the current user.
- Name
primaryWeb3WalletID?
- Type
string
- Description
The ID of the Web3 wallet to set as primary. It must be verified, and present on the current user.
- Name
username?
- Type
string
- Description
The user's username. It must be unique across your instance.
- Name
- be used when providing a
password
. - Description
- Name
profileImageID?
- Type
string
- Description
The ID of the image to set as the user's profile image.
- Name
password?
- Type
string
- Description
The plaintext password to give the user. Must be at least 8 characters long, and can not be in any list of hacked passwords.
- Name
passwordDigest?
- Type
string
- Description
In case you already have the password digests and not the passwords, you can use them for the newly created user via this property. The digests should be generated with one of the supported algorithms. The hashing algorithm can be specified using the
password_hasher
property.
- Name
passwordHasher?
- Type
'argon2i' | 'argon2id' | 'bcrypt' | 'bcrypt_sha256_django' | 'md5' | 'pbkdf2_sha256' | 'pbkdf2_sha256_django' | 'pbkdf2_sha1' | 'phpass' | 'scrypt_firebase' | 'scrypt_werkzeug' | 'sha256'
- Description
The hashing algorithm that was used to generate the password digest. Each of the supported hashers expects the incoming digest to be in a particular format. See the Clerk Backend API reference for more information.
- Name
skipPasswordChecks?
- Type
boolean
- Description
When set to
true
, all password checks are skipped. It is recommended to use this method only when migrating plaintext passwords to Clerk. Upon migration the user base should be prompted to pick stronger password.
- Name
skipPasswordRequirement?
- Type
boolean
- Description
When set to
true
, password is not required anymore when creating the user and can be omitted. This is useful when you are trying to create a user that doesn't have a password, in an instance that is using passwords. You cannot use this flag if password is the only way for a user to sign into your instance.
- Name
signOutOfOtherSessions?
- Type
boolean
- Description
Set to
true
to sign out the user from all their active sessions once their password is updated. This parameter can only be used when providing apassword
.
- Name
totpSecret?
- Type
string
- Description
In case TOTP is configured on the instance, you can provide the secret to enable it on the newly created user without the need to reset it. Currently, the supported options are:
- Period: 30 seconds
- Code length: 6 digits
- Algorithm: SHA1
- Name
backupCodes?
- Type
string[]
- Description
If backup codes are configured on the instance, you can provide them to enable it on the newly created user without the need to reset them. You must provide the backup codes in plain format or the corresponding bcrypt digest.
- Name
publicMetadata?
- Type
Record<string, unknown>
- Description
Metadata saved on the user, that is visible to both your Frontend and Backend APIs.
- Name
privateMetadata?
- Type
Record<string, unknown>
- Description
Metadata saved on the user that is only visible to your Backend API.
- Name
unsafeMetadata?
- Type
Record<string, unknown>
- Description
Metadata saved on the user, that can be updated from both the Frontend and Backend APIs. Note: Since this data can be modified from the frontend, it is not guaranteed to be safe.
- Name
deleteSelfEnabled?
- Type
boolean
- Description
If
true
, the user can delete themselves with the Frontend API.
- Name
createOrganizationEnabled?
- Type
boolean
- Description
If
true
, the user can create organizations with the Frontend API.
- Name
createOrganizationsLimit?
- Type
number
- Description
An integer indicating the number of organizations that can be created by the user. If the value is
0
, then the user can create unlimited organizations. Default isnull
.
- Name
createdAt?
- Type
Date
- Description
A custom date/time denoting when the user signed up to the application, specified in RFC3339 format
For example:2012-10-20T07:15:20.902Z
.
Example
In this example, you can see that the response is the updated User
object, with a firstName
and lastName
of "John"
and "Wick"
respectively.
Backend API (BAPI) endpoint
This method in the SDK is a wrapper around the BAPI endpoint PATCH/users/{user_id}
. See the BAPI reference for more information.
Feedback
Last updated on