- 
                Notifications
    You must be signed in to change notification settings 
- Fork 110
New D365EntraIntegration
Enable the Microsoft Entra ID integration on a cloud hosted environment (CHE).
New-D365EntraIntegration -ClientId <String> [-CertificateName <String>] [-CertificateExpirationYears <Int32>]
 [-NewCertificateFile <String>] [-NewCertificatePrivateKeyFile <String>] [-CertificatePassword <SecureString>]
 [-Force] [-WhatIf] [-Confirm] [<CommonParameters>]
New-D365EntraIntegration -ClientId <String> -ExistingCertificateFile <String>
 [-ExistingCertificatePrivateKeyFile <String>] [-CertificatePassword <SecureString>] [-Force] [-WhatIf]
 [-Confirm] [<CommonParameters>]
Enable the Microsoft Entra ID integration by executing some of the steps described in https://learn.microsoft.com/en-us/dynamics365/fin-ops-core/dev-itpro/dev-tools/secure-developer-vm#external-integrations. The integration can either be enabled with an existing certificate or a new self-signed certificate can be created. If a new certificate is created and the integration is also to be enabled on other environments with the same certificate, a certificate password must be specified in order to create a certificate private key file.
The steps executed are:
- 
- Create a self-signed certificate and save it to Desktop or use a provided certificate.
 
- 
- Install the certificate to the "LocalMachine" certificate store.
 
- 
- Grant NetworkService READ permission to the certificate (only on cloud-hosted environments).
 
- 
- Update the web.config with the application ID and the thumbprint of the certificate.
 
- 
- Add the application registration to the WIF config.
 
- 
- Clear cached LCS configuration in AxDB.
 
- 
- Restart the IIS service.
 
To execute the steps, the id of an Azure application must be provided. The application must have the following API permissions:
- Dynamics ERP - This permission is required to access finance and operations environments.
- Microsoft Graph (User.Read.All and Group.Read.All permissions of the Application type).
- Dynamics Lifecylce service (permission of type Delegated)
The URL of the finance and operations environment must also be added to the RedirectURI in the Authentication section of the Azure application. Finally, after running the cmdlet, if a new certificate was created, it must be uploaded to the Azure application.
New-D365EntraIntegration -ClientId e70cac82-6a7c-4f9e-a8b9-e707b961e986
Enables the Entra ID integration with a new self-signed certificate named "CHEAuth" which expires after 2 years.
New-D365EntraIntegration -ClientId e70cac82-6a7c-4f9e-a8b9-e707b961e986 -CertificateName "SelfsignedCert"
Enables the Entra ID integration with a new self-signed certificate with the name "Selfsignedcert" that expires after 2 years.
New-D365EntraIntegration -AppId e70cac82-6a7c-4f9e-a8b9-e707b961e986 -CertificateName "SelfsignedCert" -CertificateExpirationYears 1
Enables the Entra ID integration with a new self-signed certificate with the name "SelfsignedCert" that expires after 1 year.
$securePassword = Read-Host -AsSecureString -Prompt "Enter the certificate password"
PS C:\> New-D365EntraIntegration -AppId e70cac82-6a7c-4f9e-a8b9-e707b961e986 -CertificatePassword $securePassword
Enables the Entra ID integration with a new self-signed certificate with the name "CHEAuth" that expires after 2 years, using the provided password to generate the private key of the certificate. The certificate file and the private key file are saved to the Desktop of the current user.
$securePassword = Read-Host -AsSecureString -Prompt "Enter the certificate password"
PS C:\> New-D365EntraIntegration -AppId e70cac82-6a7c-4f9e-a8b9-e707b961e986 -ExistingCertificateFile "C:\Temp\SelfsignedCert.cer" -ExistingCertificatePrivateKeyFile "C:\Temp\SelfsignedCert.pfx" -CertificatePassword $securePassword
Enables the Entra ID integration with the certificate file "C:\Temp\SelfsignedCert.cer", the private key file "C:\Temp\SelfsignedCert.pfx" and the provided password to install it.
The Azure Registered Application Id / Client Id obtained while creating a Registered App inside the Azure Portal. It is assumed that an application with this id already exists in Azure.
Type: String
Parameter Sets: (All)
Aliases: AppId
Required: True
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: FalseThe path to a certificate file. If this parameter is provided, the cmdlet will not create a new certificate.
Type: String
Parameter Sets: ExistingCertificate
Aliases:
Required: True
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: FalseThe path to a certificate private key file. If this parameter is not provided, the certificate can be installed to the certificate store, but the NetworkService cannot be granted READ permission.
Type: String
Parameter Sets: ExistingCertificate
Aliases:
Required: False
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: FalseThe name for the certificate. By default, it is named "CHEAuth".
Type: String
Parameter Sets: NewCertificate
Aliases:
Required: False
Position: Named
Default value: CHEAuth
Accept pipeline input: False
Accept wildcard characters: FalseThe number of years the certificate is valid. By default, it is valid for 2 years.
Type: Int32
Parameter Sets: NewCertificate
Aliases:
Required: False
Position: Named
Default value: 2
Accept pipeline input: False
Accept wildcard characters: FalseThe path to the certificate file that will be created. By default, it is created on the Desktop of the current user.
Type: String
Parameter Sets: NewCertificate
Aliases:
Required: False
Position: Named
Default value: "$env:USERPROFILE\Desktop\$CertificateName.cer"
Accept pipeline input: False
Accept wildcard characters: FalseThe path to the certificate private key file that will be created. By default, it is created on the Desktop of the current user.
Type: String
Parameter Sets: NewCertificate
Aliases:
Required: False
Position: Named
Default value: "$env:USERPROFILE\Desktop\$CertificateName.pfx"
Accept pipeline input: False
Accept wildcard characters: FalseThe password for the certificate private key file. If not provided when creating a new certificate, no private key file will be created. If not provided when using an existing certificate, the private key file cannot be installed.
Type: SecureString
Parameter Sets: (All)
Aliases:
Required: False
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: FalseForces the execution of some of the steps. For example, if a certificate with the same name already exists, it will be deleted and recreated.
Type: SwitchParameter
Parameter Sets: (All)
Aliases:
Required: False
Position: Named
Default value: False
Accept pipeline input: False
Accept wildcard characters: FalseExecutes the cmdlet until the first operation that would change the state of the system, without executing that operation. Subsequent operations are likely to fail. This is currently not fully implemented and should not be used.
Type: SwitchParameter
Parameter Sets: (All)
Aliases: wi
Required: False
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: FalsePrompts for confirmation before each operation of the cmdlet that changes the state of the system.
Type: SwitchParameter
Parameter Sets: (All)
Aliases: cf
Required: False
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: FalseThis cmdlet supports the common parameters: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutVariable, -OutBuffer, -PipelineVariable, -Verbose, -WarningAction, and -WarningVariable. For more information, see about_CommonParameters.
Test-D365EntraIntegration can be used to validate an entra integration.
Author: Øystein Brenna (@oysbre) Author: Florian Hopfner (@FH-Inway)
- Install as a non-Administrator
- Install as a Administrator
- Import d365fo.tools module
- List available commands from d365fo.tools module
- Get help content for a command
- Start, Stop and List services
- Import users into the D365FO environment
- Import external users into the D365FO environment
- Enable users in the D365FO environment
- Update users in the D365FO environment
- Provision D365FO environment to new Azure AD tenant
- Import a bacpac file into a Tier1 environment
- List modules / models
- Compile module
- Install AzCopy
- Install SqlPackage
- Install Nuget
- Speed up LCS download via AzCopy
- Download latest bacpac from LCS via AzCopy
- Register NuGet source
- Configure Azure Logic App
- Fix AzureStorageConfig
- Run a runnable class
- Update users in environment
- Work with Azure Storage Account
- Work with packages, resource label files, language and lables
- Working with the different D365 services