Creates a new user, either End-User or Service User.
End-User Accounts are assigned to employees. To create an end user account, the accountType field must be NORMAL.
Service User Accounts are a type of account used for bots or applications, rather than end-users. To create a service user account, the accountType field must be SYSTEM.
Since 20.14, userSystemInfo from the payload includes suspension info:
if user is active, then the suspended attribute is set to false,
if user is suspended, then the suspended attribute is set to true and both suspendedUntil and suspensionReason are as well included in the payload.
Please note that even if the suspendedUntil date is in the past, the user will remain suspended=true until he first logs on the client after the suspension ended. The suspended info are then automatically updated.
See the Suspend User Account endpoint for more information.
🚧 Required Permissions
Calling this endpoint requires the ACCESS_USER_PROVISIONING_API and ACCESS_ADMIN_API privileges.
See Bot Permissions for a list of roles and associated privileges.
The Password Object
The password object is optional for end-user accounts (NORMAL). For example, if your organization utilizes SSO, you may not want to specify the password.
Please note the password object is not used for service accounts (SYSTEM) and therefore cannot be entered in the request payload.
The following code snippets can be used to generate hashed passwords. Two implementations are provided, one using built-in Java classes and the other with Postman.
// Example with Postman, as a Pre-Request script.constpassword='SymphonyRocks123456789!'; // Replace with your password// Generate a random salt of specified lengthfunctiongenerateSalt(length) {returnCryptoJS.lib.WordArray.random(128/8);}// PBKDF2 function using CryptoJSfunctionderivePBKDF2(password, salt, iterations, keyLength) {returnCryptoJS.PBKDF2(password, salt, { keySize: keyLength /32,// Key size in words (32-bit units) iterations: iterations, hasher:CryptoJS.algo.SHA256 });}// Parametersconstiterations=10000; // Number of iterationsconstkeyLength=256; // Key length in bits (256 = 32 bytes)constsaltLength=16; // Salt length in characters// Generate random saltsconsthSalt=generateSalt(saltLength);constkhSalt=generateSalt(saltLength);// Derive PBKDF2 hashesconsthPassword=derivePBKDF2(password, hSalt, iterations, keyLength);constkhPassword=derivePBKDF2(password, khSalt, iterations, keyLength);// Convert salts and hashes to B64 stringsconsthSaltB64=CryptoJS.enc.Base64.stringify(hSalt);constkhSaltB64=CryptoJS.enc.Base64.stringify(khSalt);consthPasswordB64=CryptoJS.enc.Base64.stringify(hPassword);constkhPasswordB64=CryptoJS.enc.Base64.stringify(khPassword);// Set Postman environment variables for use in the requestpm.environment.set('hSalt', hSaltB64);pm.environment.set('hPassword', hPasswordB64);pm.environment.set('khSalt', khSaltB64);pm.environment.set('khPassword', khPasswordB64);
Password. Stored as derived password in both the Pod and the Key Manager using PBKDF2 function. Number of iterations should be 10000 and desired length 256 bits.