ML
    • Recent
    • Categories
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login

    PowerShell - Create New AD User Using Prompts and Variables

    IT Discussion
    powershell ad windows
    6
    26
    4.9k
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • W
      wrx7m
      last edited by wrx7m

      I created the following PowerShell script that works to create a new AD user and respective attributes, as long as I update the script with the user's name every time I want to run it. Here is what I have:

      Import-Module ActiveDirectory
      New-ADUser -Name "John Doe" -GivenName "John" -Surname "Doe" -SamAccountName "John" -DisplayName "John Doe" -UserPrincipalName "John@upndomain.com" -Country "US" -EmailAddress John.Doe@email1.com -Path "OU=email1.com,OU=User Accounts,DC=ADDomain,DC=com" -AccountPassword(Read-Host -AsSecureString "Input Password") -Enabled $true
      Set-ADUser -Identity John -Add @{Proxyaddresses="SMTP:John.Doe@email1.com", "smtp:John.Doe@email2.com", "smtp:John.Doe@email3.com", "smtp:John.Doe@email4.com", "smtp:John.Doe@email5.com", "smtp:John.Doe@email6.com"}
      Add-ADGroupMember -Identity Office365Users -Members John
      

      I would like to do something with prompts to set variables regarding the name. I have tried doing this, but can't get the combined variables with a period in between working properly for the email addresses, the space in between the first and the last name for name/display name and possibly adding them to the the various domains, both UPN and email. Here is what I have so far.

      Import-Module ActiveDirectory
      $GivenName = Read-Host -Prompt "Enter First Name"
      $Surname = Read-Host -Prompt "Enter Last Name"
      $SecurePW = Read-Host -Prompt "Enter a Password" -AsSecureString
      New-Variable -Name $DisplayName = "${GivenName}${Surname}"
      New-ADUser -Name "$DisplayName" `
                 -AccountPassword $SecurePW  `
                 -SamAccountName $GivenName `
                 -DisplayName $DisplayName `
                 -PasswordNeverExpires $True `
                 -UserPrincipalName $GivenName + "@UPNDomain.com" `
                 -Country US `
                 -EmailAddress $GivenName + "." + $Surname + "@email1.com" `
                 -Path "OU=email1.com,OU=User Accounts,DC=upn,DC=com" `
                 -Enabled $True
      Set-ADUser -Identity $GivenName -Add @{Proxyaddresses="SMTP:$GivenName.$Surname@email1.com", "smtp:$GivenName.$Surname@email2.com", "smtp:$GivenName.$Surname@email3.com", "smtp:$GivenName.$Surname@email4.com", "smtp:$GivenName.$Surname@email5.com", "smtp:$GivenName.$Surname@email6.com"}
      Add-ADGroupMember -Identity Office365Users -Members $GivenName
      

      I get an error starting at New-ADUser : A positional parameter cannot be found that accepts argument '+'. on line 6 char1. I have messed around with syntax several times, so it may or may not be "complete", but I do know that it is wrong LOL

      J 1 Reply Last reply Reply Quote 2
      • J
        JaredBusch @wrx7m
        last edited by JaredBusch

        @wrx7m

        -UserPrincipalName "$GivenName@UPNDomain.com" `
        -EmailAddress "$GivenName.$Surname@email1.com" `
        
        1 Reply Last reply Reply Quote 2
        • D
          dafyre
          last edited by dafyre

          @wrx7m said in PowerShell - Create New AD User Using Prompts and Variables:

                 -UserPrincipalName $GivenName + "@UPNDomain.com" `
          

          Try changing your lines like that to like this...
          -UserPrincipalName "$GivenName@UPNDomain.com"

          You'll need to do this for anything that has a plus sign in it.

          Edit: You'll need to fix the Email Address too.

          1 Reply Last reply Reply Quote 2
          • N
            NerdyDad
            last edited by

            You're going to need to do some concentanation on your usernames in order to get the period included in the spot you want. Take a look at my script. There is a place where it is concentanated for the first name and last name for the email address and last name + first initial for usernames.

            https://mangolassi.it/topic/13324/creating-new-user-without-o365-with-powershell

            1 Reply Last reply Reply Quote 2
            • N
              NerdyDad
              last edited by

              @wrx7m said in PowerShell - Create New AD User Using Prompts and Variables:

              -EmailAddress $GivenName + "." + $Surname + "@email1.com" `

              Here, I think you're going to want to try something like:
              -join ($GivenName,".",$SurName,"@email1.com")

              1 Reply Last reply Reply Quote 2
              • W
                wrx7m
                last edited by wrx7m

                What about creating a new variable by combining two existing variables? (For the display name)

                J N 2 Replies Last reply Reply Quote 0
                • J
                  JaredBusch @wrx7m
                  last edited by

                  @wrx7m said in PowerShell - Create New AD User Using Prompts and Variables:

                  What about creating a new variable by combining two existing variables? (For the display name)

                  Of course you can. But why clutter up more variables?

                  W 1 Reply Last reply Reply Quote 0
                  • W
                    wrx7m @JaredBusch
                    last edited by

                    @JaredBusch - Well, it didn't work when I used the first 2 together. At least, with the syntax I had. Also, it would be nice to know how to do it. But, I would settle for getting the display name Jon Doe with a space in it using the 2 existing variables.

                    D 1 Reply Last reply Reply Quote 0
                    • D
                      dafyre @wrx7m
                      last edited by

                      @wrx7m said in PowerShell - Create New AD User Using Prompts and Variables:

                      @JaredBusch - Well, it didn't work when I used the first 2 together. At least, with the syntax I had. Also, it would be nice to know how to do it. But, I would settle for getting the display name Jon Doe with a space in it using the 2 existing variables.

                      $DisplayName="$GivenName $SurName" ?

                      W N 2 Replies Last reply Reply Quote 0
                      • W
                        wrx7m @dafyre
                        last edited by

                        @dafyre I'll try that. I think I may have already tried it. I did all sorts of iterations.

                        1 Reply Last reply Reply Quote 0
                        • W
                          wrx7m
                          last edited by

                          Import-Module ActiveDirectory
                          $GivenName = Read-Host -Prompt "Enter First Name"
                          $Surname = Read-Host -Prompt "Enter Last Name"
                          $SecurePW = Read-Host -Prompt "Enter a Password" -AsSecureString
                          $DisplayName = "$GivenName $Surname"
                          New-ADUser -Name $DisplayName `
                          

                          Results in this error

                          New-ADUser : A positional parameter cannot be found that accepts argument '+'.
                          At \\FP02\it\Scripts\AD\AD-InitialUserCreationVariables.ps1:6 char:1
                          + New-ADUser -Name $DisplayName `
                          + ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
                              + CategoryInfo          : InvalidArgument: (:) [New-ADUser], ParameterBindingException
                              + FullyQualifiedErrorId : PositionalParameterNotFound,Microsoft.ActiveDirectory.Management.Commands.NewADUser
                          
                          1 Reply Last reply Reply Quote 0
                          • W
                            wrx7m
                            last edited by

                            If I get rid of the attempt to combine the 2 existing variables into a 3rd, I get this error.

                            New-ADUser : A positional parameter cannot be found that accepts argument '+'.
                            At \\FP02\it\Scripts\AD\AD-InitialUserCreationVariables.ps1:5 char:1
                            + New-ADUser -Name "$GivenName $Surname" `
                            + ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
                                + CategoryInfo          : InvalidArgument: (:) [New-ADUser], ParameterBindingException
                                + FullyQualifiedErrorId : PositionalParameterNotFound,Microsoft.ActiveDirectory.Management.Commands.NewADUser
                            
                            D PhlipElderP 2 Replies Last reply Reply Quote 0
                            • D
                              dafyre @wrx7m
                              last edited by

                              @wrx7m said in PowerShell - Create New AD User Using Prompts and Variables:

                              If I get rid of the attempt to combine the 2 existing variables into a 3rd, I get this error.

                              New-ADUser : A positional parameter cannot be found that accepts argument '+'.
                              At \\FP02\it\Scripts\AD\AD-InitialUserCreationVariables.ps1:5 char:1
                              + New-ADUser -Name "$GivenName $Surname" `
                              + ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
                                  + CategoryInfo          : InvalidArgument: (:) [New-ADUser], ParameterBindingException
                                  + FullyQualifiedErrorId : PositionalParameterNotFound,Microsoft.ActiveDirectory.Management.Commands.NewADUser
                              

                              If you did not fix UserPrincipalName and EmailAddress as well, it will still error.

                              1 Reply Last reply Reply Quote 0
                              • J
                                JaredBusch
                                last edited by

                                This is why you run things manually and not in scripts until you know WTF you are doing.

                                Use the PowerShell ISE, that is what it is for.

                                You also do not have the Country in quotes. It is a string value.

                                W 1 Reply Last reply Reply Quote 0
                                • N
                                  NerdyDad @wrx7m
                                  last edited by

                                  @wrx7m said in PowerShell - Create New AD User Using Prompts and Variables:

                                  What about creating a new variable by combining two existing variables? (For the display name)

                                  $displayName = join ($GivenName," ",$SurName)

                                  1 Reply Last reply Reply Quote 0
                                  • N
                                    NerdyDad @dafyre
                                    last edited by

                                    @dafyre said in PowerShell - Create New AD User Using Prompts and Variables:

                                    @wrx7m said in PowerShell - Create New AD User Using Prompts and Variables:

                                    @JaredBusch - Well, it didn't work when I used the first 2 together. At least, with the syntax I had. Also, it would be nice to know how to do it. But, I would settle for getting the display name Jon Doe with a space in it using the 2 existing variables.

                                    $DisplayName="$GivenName $SurName" ?

                                    This would result in literally being given $GivenName $SurName whenever you ask for $DisplayName.

                                    D 1 Reply Last reply Reply Quote 0
                                    • D
                                      dafyre @NerdyDad
                                      last edited by

                                      @NerdyDad said in PowerShell - Create New AD User Using Prompts and Variables:

                                      @dafyre said in PowerShell - Create New AD User Using Prompts and Variables:

                                      @wrx7m said in PowerShell - Create New AD User Using Prompts and Variables:

                                      @JaredBusch - Well, it didn't work when I used the first 2 together. At least, with the syntax I had. Also, it would be nice to know how to do it. But, I would settle for getting the display name Jon Doe with a space in it using the 2 existing variables.

                                      $DisplayName="$GivenName $SurName" ?

                                      This would result in literally being given $GivenName $SurName whenever you ask for $DisplayName.

                                      That's what he wants as I see his code above.

                                      1 Reply Last reply Reply Quote 0
                                      • J
                                        JaredBusch
                                        last edited by

                                        0_1542138216766_4a3fe9d1-b314-4779-ad49-cb5b25107eaa-image.png

                                        N 1 Reply Last reply Reply Quote 0
                                        • N
                                          NerdyDad @JaredBusch
                                          last edited by

                                          @JaredBusch said in PowerShell - Create New AD User Using Prompts and Variables:

                                          0_1542138216766_4a3fe9d1-b314-4779-ad49-cb5b25107eaa-image.png

                                          Corrected. Thank you sir.

                                          1 Reply Last reply Reply Quote 0
                                          • W
                                            wrx7m @JaredBusch
                                            last edited by

                                            @JaredBusch said in PowerShell - Create New AD User Using Prompts and Variables:

                                            This is why you run things manually and not in scripts until you know WTF you are doing.

                                            Use the PowerShell ISE, that is what it is for.

                                            You also do not have the Country in quotes. It is a string value.

                                            I am running it manually and I am running it in ISE.

                                            J 1 Reply Last reply Reply Quote 0
                                            • 1
                                            • 2
                                            • 1 / 2
                                            • First post
                                              Last post