0 votes

We just finalize the purchase to our software license company and I want to try to automate more with Adaxes.

Is there a way that it can automatically create mailboxes in Office 365, or should I continue to create them in our on-premise Exchange 2010 server (that relays out to 365) and set up a script to migrate them to Office 365?

by (440 points)

1 Answer

0 votes
by (216k points)
selected by
Best answer

Hello,

You will not be able to create user mailboxes in Office 365 with the built-in Adaxes functionality, but you can use PowerShell scripts for this purpose. You can use the PowerShell scripts in Business Rules, Custom Commands and Scheduled Tasks with the help of the Run a program or PowerShell script action. For example, you can create a Business Rule triggered after creating a user and create mailboxes in Office 365 for all newly created users or use the script in a Custom Command to be able to create a mailbox for any user on demand.

For information on how to create a Business Rule that runs a script automatically after creating a user, see the following tutorial: http://www.adaxes.com/tutorials_Automat ... ngUser.htm.

To be able to create mailboxes, Adaxes needs the credentials of a user with the rights to create mailboxes in your Office 365 organization. You have two options for this: you can either store the credentials directly in the body of the script or store them in a secure storage.

The following script creates Office 365 mailboxes for users in your Active Directory. The credentials are stored directly in the body of the script:

# Credentials required to create mailboxes in your cloud-based organization
$userID = "user@domain.com" # TODO: modify me
$password = ConvertTo-SecureString -AsPlainText -Force -String "Password" # TODO: modify me
# Domain name in your cloud-based organization
$userDomainName = "domain.com" # TODO: modify me
# Password to the newly created mailbox
$userPassword = ConvertTo-SecureString -String 'password' -AsPlainText -Force # TODO: modify me

$credential = New-Object System.Management.Automation.PsCredential($userID,$password)

$session = New-PSSession -ConfigurationName Microsoft.Exchange -ConnectionUri "https://ps.outlook.com/powershell/" `
    -Credential $credential -Authentication Basic -AllowRedirection

Import-PSSession $session

New-MailUser -Name "%fullname%" -MicrosoftOnlineServicesID "%username%@$userDomainName" -Password $userPassword

Remove-PSSession $session

In the script, $userID and $password specify the credentials of a user who has sufficient permissions to create mailboxes in your Office 365 organization, $userDomainName specifies the name of the domain that is registered in your Office 365 organization and that will be used for the newly created mailboxes, and $userPassword specifies the default password that will be set initially for all mailboxes.

The following script creates Office 365 mailboxes for users in your Active Directory. The credentials are imported from the secure storage in the folder specifies by $credentialDirectoryPath:

$credentialDirectoryPath = "C:\ScriptDirectory\Credentials" # TODO: modify me

# Domain name in your cloud-based organization
$userDomainName = "domain.com" # TODO: modify me
# Password to the newly created mailbox
$userPassword = ConvertTo-SecureString -String 'password' -AsPlainText -Force # TODO: modify me

# Check credentials directory path
if(!(Test-Path -Path $credentialDirectoryPath))
{
    $Context.LogMessage("The credentials folder was not found. Make sure that $credentialDirectoryPath exists.", "Error") # TODO: modify me
    return
}
# Read credentials from the file
$file = Get-ChildItem -Path $credentialDirectoryPath
if(!$file)
{
    $Context.LogMessage("The credentials file was not found.", "Error") # TODO: modify me
    return
}

$userID = (Get-Content -Path $file.FullName)[0]
$passwordEncryptedString = (Get-Content -Path $file.FullName)[1]
$password = ConvertTo-SecureString -String $passwordEncryptedString

$credential = New-Object System.Management.Automation.PsCredential($userID,$password)

$session = New-PSSession -ConfigurationName Microsoft.Exchange -ConnectionUri "https://ps.outlook.com/powershell/" `
    -Credential $credential -Authentication Basic -AllowRedirection

Import-PSSession $session

New-MailUser -Name "%fullname%" -MicrosoftOnlineServicesID "%username%@$userDomainName" -Password $userPassword

Remove-PSSession $session

In the script, $credentialDirectoryPath specifies the path to the secure storage that stores the credentials of a user who has sufficient permissions to create mailboxes in your Office 365 organization, $userDomainName specifies the name of the domain that is registered in your Office 365 organization and that will be used for the newly created mailboxes, and $userPassword specifies the default password that will be set initially for all mailboxes.

To be able to use the script, first you need to create a secure storage with credentials of a user who has sufficient permissions to create mailboxes in your Office 365 organization. To do this:

  1. Create a new text file. The text file should contain only two lines:

    • ID of the user who has sufficient permissions to create mailboxes in your Office 365 organization.

    • Password to the account of the user.
      For example:

        ```powershell
        user@domain.com
        P@$$w0rd
      
        ```
  2. Run the following script in PowerShell. The script will import the credentials specified in the text file to a secure storage. The secure storage will be located in the same folder as the text file, in the Credentials subfolder. The password will be encrypted using the standard Windows Encryption API, which means that only the user whose credentials were used to launch the script will be able to read the credentials in the secure storage. Since Adaxes uses the account of the default service administrator to perform all operations in Active Directory (including launching scripts), you will need to run the script with the credentials of Adaxes default service administrator to be able to use the credentials stored in the secure storage.

    To import credentials from the text file created on the previous step, you need to launch the script with the -credentialFilePath full_file_path parameter, where full_file_path is the path to the text file that you've created on the previous step, for example:
    .ImportCredentinal.ps1 -credentialFilePath C:\ScriptDirectory\credentials.txt

    Optionally, you can also specify the -deleteOldCredentials parameter. If this parameter is specified, the script will purge the directory with credentials before creating any new files.

    Here's the text of the script that imports credentials to a secure storage:

     Param($credentialFilePath, [switch]$deleteOldCredentials) # Run the script with command line parameter -credentialFilePath (credentials file path) and optional parameter -deleteOldCredentials
    
     $scriptDirectoryPath = [System.IO.Path]::GetDirectoryName($myInvocation.MyCommand.Definition)
    
     # Create a directory for files with credentials
     $credentialDirectoryPath = $scriptDirectoryPath + "\Credentials"
     if ($deleteOldCredentials)
     {
         if ((Test-Path -Path $credentialDirectoryPath))
         {
             Get-Item -Path $credentialDirectoryPath | Remove-Item -Force -Recurse
         }
     }
    
     if (!(Test-Path -Path $credentialDirectoryPath))
     {
         New-Item -ItemType directory -Path $credentialDirectoryPath | Out-Null
     }
     $credentialDirectory = Get-Item -Path $credentialDirectoryPath
    
     $filePath = $credentialDirectory.FullName + "\" + "credentials.data"
     if((Test-Path -Path $filePath))
     {
         Get-Item -Path $filePath | Remove-Item -Force -Recurse
     }
     $file = New-Item $filePath -Type file
    
     Set-Content -Path $file.FullName -Value (Get-Content $credentialFilePath)[0]
     ConvertTo-SecureString  (Get-Content $credentialFilePath)[1] -AsPlainText -Force | ConvertFrom-SecureString | Add-Content $file
    
     Write-Host "Import complete"
    
  3. When credentials are imported into the secure storage, you no longer need the text file. You may safely delete it.

0

Hello,

Our script guys have already proceeded to the task, but it'll take quite a lot of time to complete. We'll update the topic as soon as they come up with something.

0

thanks a lot!

0

Hello,

It took our script guys quite a while to set up an environment in Office 365, but finally the script is ready. For the script to be able to perform the necessary operations, you need to specify the following:

  • Credentials of a user with sufficient permissions to provision users for Office 365. The credentials are specified directly in the script by $office365AdminName and $office365AdminPassword.
  • Credentials of your local Exchange domain administrator. They are specified using the Run As function of the Run a program or PowerShell script action (see below) that launches the script.
  • The name of your Office 365 domain. It is specified directly in the script by $office365DeliveryDomain.

How to add the script to a Business Rule and specify the credentials of the local Exchange domain administrator:

  1. Launch Adaxes Administration Console.

  2. Expand the service node that represents your Adaxes service.

  3. Locate the Business Rule that you would like to add the script to. For example, you can select a Business Rule that creates mailboxes in your local on-premises Exchange organization.

  4. Right-click the set of actions and conditions that you would like to add the script to and click Add Action. We recommend adding the script to the same action/condition set that creates mailboxes in the on-premises Exchange organization.

  5. Select the Run a program or PowerShell script action.

  6. Paste the following script in the Script field.

     # Credentials of a user who has sufficient permissions to provision users for Office 365
     $office365AdminName = "administrator@example.onmicrosoft.com" # TODO: modify me
     $office365AdminPassword = ConvertTo-SecureString -AsPlainText -Force -String "Password" # TODO: modify me
    
     $office365DeliveryDomain = "example.mail.onmicrosoft.com" # TODO: modify me
    
     $office365Credentials = New-Object -TypeName System.Management.Automation.PSCredential($office365AdminName, $office365AdminPassword)
    
     $session = New-PSSession -ConfigurationName Microsoft.Exchange -ConnectionUri "https://ps.outlook.com/powershell/" -Credential $office365Credentials -Authentication Basic -AllowRedirection
     Import-PSSession $session
    
     # Credentials of the local Exchange domain administrator
     $localAdminName = $Context.RunAs.UserName + "@" + $Context.RunAs.Domain
     $localAdminPassword = ConvertTo-SecureString -AsPlainText -Force -String $Context.RunAs.Password 
     $localAdminCredentials = New-Object -TypeName System.Management.Automation.PSCredential($localAdminName, $localAdminPassword)
    
     $localDomain = $Context.GetObjectDomain("%distinguishedName%")
    
     try
     {
         $result = New-MoveRequest -Identity "%username%" -Remote -RemoteHostName $localDomain -TargetDeliveryDomain $office365DeliveryDomain -RemoteCredential $localAdminCredentials -ErrorAction Stop
     }
     catch
     {
         $Context.LogMessage($_.Exception.Message, "Error")
     }
    
     Remove-PSSession $Session
    
     if ($result -ne $NULL)
     {
         $Context.LogMessage("Mailbox move request created successfully. Check Exchange logs for details." , "Information")
     }
    
  7. Now, you need to specify the credentials of your local Exchange domain administrator. To do this, switch the radio button in the Run as section to This account and click Specify.

  8. Specify the credentials of a local Exchange domain administrator. The script will import credentials securely stored in the Run As section and use them when synchronizing a local mailbox to Office 365.

  9. Click OK.

  10. Enter a short description for the script and click OK.

  11. With the help of the up and down arrow buttons at the bottom, place this action after the action that creates mailboxes, because the script only synchronizes existing mailboxes to Office 365. Thus, a local mailbox should already exist.

  12. Save the modified Business Rule.

0

Possibly the best support of any software ever = }

0

Hello,

Thank you for your good words, we really appreciate it! :)

Related questions

0 votes
1 answer

I have a business rule to create a user in our AD, and then have it create a new O365 account and assign it a license. How can I have it create a temporary password that I specify during that business rule?

asked Jun 17, 2020 by keecit (60 points)
0 votes
1 answer

Good afternoon, Is there a script for adding a user to an already existing Office 365 Shared Mailbox? I want to add this script onto the onboarding rules I have added already.

asked May 7 by ocanizales (60 points)
0 votes
1 answer

Dear support, We are trying to achieve a situation where a user will be able to do the following: Create a mail enabled Office 365 contact. Add this office 365 contact to a ... . Hopefully you can help me on this quest. Thanks a lot and kind regards, Remco.

asked Feb 11, 2021 by remcobraspenning (20 points)
0 votes
0 answers

When attempting to assign licenses during the "after creating a user" rule we're reciving the following error. Failed to create a remote mailbox for the user. The address ' ... mail attribute to the proper format that isn't the onmicrosoft.com domain as well.

asked Sep 2, 2021 by zorps (20 points)
0 votes
1 answer

and script is but nothing is happeneing. my user in adaxe browwser has the attribute to yes

asked May 10, 2023 by fjacques (20 points)
3,588 questions
3,277 answers
8,303 comments
548,090 users