Create new AD user with unique username

317 Views Asked by At

I have a web view that takes a person's first name and last name, and tries to creates a new user in active directory using the naming context of first letter of first name + last name. This works great, however when creating multiple users with the same last name and first name that start with the same character (ie. Andy Gordan => agordan | Alex Gordan => agordan), errors are thrown because a user with the same username already exist.

How do I add an if/else statement below that checks with active directory to see if the username already exists, and if so add a middle initial after the first name (Alex M Gordan => agordan , next user entered: Andy M Gordan => amgordan).

[HttpPost]
public ActionResult Index(CreateUser model)
{
    //Domain name
    var domainName = "XXX";
    //Fully distinguished name of OU to create user in
    var location = model.Location;
    var userOU = "OU=" + location + ",OU=XXX,DC=XXX,DC=com"; 

    using (var pc = new PrincipalContext(ContextType.Domain, domainName, userOU))
    {
        using (var up = new UserPrincipal(pc))
        {
            //Creates username and display name from firstname and lastname
            **var userName = model.FirstName[0].ToString().ToLower() + model.LastName.ToString().ToLower();**

            var displayName = model.FirstName + " " + model.LastName;
            var password = "XXX";

            up.Name = displayName;
            up.DisplayName = displayName;
            up.GivenName = model.FirstName;
            up.MiddleName = model.MiddleI;
            up.Surname = model.LastName;
            up.SamAccountName = userName;
            up.EmailAddress = userName + "@XXX.com";
            up.UserPrincipalName = userName + "@XXX.com";
            up.SetPassword(password);
            up.Enabled = true;
            up.ExpirePasswordNow();

            try
            {
                //Attempt to save the account to AD
                up.Save();
            }
            catch (Exception e)
            {
                ModelState.AddModelError("", "Exception creating user object. " + e);
                return View(model);
            }

            //Set department to add
            DirectoryEntry entry = up.GetUnderlyingObject() as DirectoryEntry;

            //DirectoryEntry group = entry.Children.Add("CN="+ )
            entry.Properties["department"].Value = model.Department;
            //entry.Properties["member"].Add(up);
            try
            {
                //try and commit the changes
                entry.CommitChanges();
            }
            catch(Exception e)
            {
                ModelState.AddModelError("", "Exception adding department. " + e);
                return View(model);
            }
        }
    }

    //Redirect to completed page if successful
    return RedirectToAction("Completed");

}//POST Index
0

There are 0 best solutions below