The UserRegistrationAdminAdd command allows an administrator to create a new user.
If userId is specified, and that user is a guest user, this command will register that user. Alternatively, if that user is a registered user, this command will act as UserRegistrationAdminUpdate to update information of the specified registered user.
To run this command, the administrator must login first. After a user is created, the user is not automatically logged on, i.e., the new user does not become the current user in the command context.
A B2B user can be created by specified profileType equals to 'B'. To register a user under an organization or organizational unit, specify the parameter parentMemberId to the orgEntityId of the organization or organizational unit.
The information of the new user is stored in the MEMBER, USERS, USERREG, MBRREL, USERPROF, BUSPROF, USERDEMO and ADDRESS tables.
Use this command with SSL (Secure Sockets Layer) to ensure that the information are encrypted. To do so type the command with the HTTPS secure protocol.
The parameter URL, logonId, logonPassword and logonPasswordVerify are mandatory. The rest of the parameters are all optional.
Behavior
- Calls an empty task command PreUserRegistrationAdminAddCmd. Store Developers can overwrite it change the input to the command.
- Create a new record in USERS table with Registration Type as 'R' (registered) and populates Distinguished Name.
- Create a new record in USERREG table. If Authentication Mode is 'LDAP', the logonId field in USERREG table stores the Distinguished Name of the user and the logon password is only stored in LDAP server, not in the USERREG table.
- Member relationship information is stored in MBRREL table.
- If any field related to USERPROF, BUSPROF and USERDEMO is specified, a new record will be created in these tables, otherwise, no record will be created.
- If any field related to ADDRESS table is specified, a self address (also called register address, with selfAddress field set to '1' and nick name is same as logonId) will be created. Otherwise no record will be created in the ADDRESS table.
Each user can have at most one self address.
- Calls a task command ProcessParentMemberCmd to validate parentMemberId.
- Calls a task command ProcessProfileTypeCmd to determinate and validate profileType.
If profileType is not specified, and parentMember is not specified or is Default Organization, by default, the profileType is set to "C" and a B2C user will be created;
If profileType is not specified and parentMember is not Default Organization, by default, the profileType is set to"B" and a B2B user will be created.
- Calls a task command AuthenticationPolicyCmd to performs verification or update of a user credentials.
- If passwordExpired is not specified, default is 0 (Not Expired).
- If status is not specified, default is 1 (Enabled).
- If preferredCurrency is not specified, default is the preferred currency in command context.
- If policyAccountId is not specified, default is -1.
- If a new address need to be created but addressType is not specified, default is 'SB' (Shipping and Billing address).
- Check the required registration information parameters.
- Calls a task command AuditUserRegistrationCmd task to check the additional parameters. Store Developers need to add new code to the task command if they want a customizable check.
- If the authentication mode is 'LDAP', a user entry will be created in the LDAP server.
- If the command fails, the UserRegistrationErrorView view command is called. Upon successful completion, the specified URL is called.
- Calls an empty task command PostUserRegistrationAdminAddCmd. Store Developers can overwrite it to perform additional operations.
Exception Conditions
- URL is null (_ERR_CMD_MISSING_PARAM).
- The length of URL length equals 0 (_ERR_CMD_INVALID_PARAM).
- logonId is null (_ERR_CMD_MISSING_PARAM).
- The length of logonId equals 0 (_ERR_CMD_INVALID_PARAM).
- logonId already exists in database (EC_UREG_ERR_LOGONID_EXISTS).
- In LDAP Mode, the formulated Distinguished Name already exist in LDAP Sever or WCS Database (_ERR_RDN_ALREADY_EXIST).
- logonPassword is null (_ERR_CMD_MISSING_PARAM).
- The length of logonPassword equals 0 or greater than 70 (_ERR_CMD_INVALID_PARAM).
- logonPasswordVerify is null (_ERR_CMD_MISSING_PARAM).
- logonPassword is not equal to logonPasswordVerify (EC_UREG_ERR_PASSWORDS_NOT_SAME).
- profileType is not null and not equal to 'B' or 'C' (_ERR_CMD_INVALID_PARAM).
- parentMemberId is not null and not a foreign key set to the ORGENTITY table (_ERR_CMD_INVALID_PARAM).
- status is not null and does not equals to '1' or '0'(_ERR_CMD_INVALID_PARAM).
- passwordExpired is not null and does not equals to '1' or '0' (_ERR_CMD_INVALID_PARAM).
- passwordRetries is not null and is not an integer (_ERR_CMD_INVALID_PARAM).
- policyAccountId is not null and is not a foreign key set to the PLCYACCT table (_ERR_CMD_INVALID_PARAM).
- preferredCurrency is not null and not a foreign key set to the SETCCURR table (_ERR_CMD_INVALID_PARAM).
- preferredLanguage is not null and not a foreign key set to the LANGUAGE table (_ERR_CMD_INVALID_PARAM).
- age, income, children, household, demographicField6, publishPhone1, publishPhone2, and packageSupression is not null and not an integer (_ERR_CMD_INVALID_PARAM).