Clone the module and follow the instructions described. You need Microsoft.Graph PowerShell version 2.15.X in order to build the module.
git clone https://github.com/microsoftgraph/entra-powershell.git
cd entra-powershell
This module depends on some Microsoft Graph PowerShell modules. The following command installs the required dependencies.
# Install dependencies required to build the Microsoft Entra PowerShell General Availability (GA)
.\build\Install-Dependencies.ps1 -ModuleName Entra
Or
# Install the dependencies for the Microsoft Entra PowerShell preview
.\build\Install-Dependencies.ps1 -ModuleName EntraBeta
Tip
If you encounter Execution Policies error, run the command Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser
.
The module help files are generated from markdown documentation (using platyPS module). To install PlatyPS module, run the command Install-Module -Name PlatyPS
.
# Install PlatyPS module
Install-Module -Name PlatyPS
# Build help module for the Microsoft Entra Module
. .\build\Common-functions.ps1
Create-ModuleHelp -Module Entra // or EntraBeta for the preview version
Use a clean PowerShell session when you're building the module. The building process attempts to load the required versions of the module, which fails if another version of the dependencies is already loaded.
.\build\Create-CompatModule.ps1 -Module Entra // or EntraBeta
The generated module is in the output folder ./bin
In order to import it, you need to run Import-Module .\bin\Microsoft.Graph.Entra.psd1 -Force
Import the module and test the generated commands.
Import-Module .\bin\Microsoft.Graph.Entra.psd1 -Force
Connect-MgGraph -Scopes "User.Read.All"
Get-EntraUser -Top 10
Tip
If you are using PowerShell 5.1, you may experience the error Function <cmdlet-name> cannot be created because function capacity 4096 has been exceeded for this scope
. To fix this error, run the command: $MaximumFunctionCount=32768
, then retry importing the module again.
$MaximumFunctionCount=32768
For migration scenarios (if you have a script with AzureAD commands), you can use the command Enable-EntraAzureADAlias
to enable aliases to emulate AzureAD PowerShell module commands. You need to remove AzureAD and AzureAD Preview modules to avoid collisions via the command Remove-Module AzureAD
or Remove-Module AzureADPreview
Enable-EntraAzureADAlias
Connect-Graph
Get-AzureADUser
Install a test version (optional), which is recommended if you're trying to test with automation, which tries to load the module from the default PowerShell modules folder.
. .\build\Common-functions.ps1
Create-ModuleFolder
Register-LocalGallery
.\build\Publish-LocalCompatModule.ps1 -Install
Unregister-LocalGallery
#When you install, you can load the module without the Path to the files.
Import-Module Microsoft.Graph.Entra.psd1 -Force
The snippet in the optional testing section publishes the module to a local repository and installs the module.
- Installation error:
cannot be loaded because running scripts is disabled on this system. For more information, see about_Execution_Policies at https:/go.microsoft.com/fwlink/?LinkID=135170.
To solve this error, run the command:
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser
- Installation error:
Function <cmdlet-name> cannot be created because function capacity 4096 has been exceeded for this scope.
To solve this error, run the command:
$MaximumFunctionCount=32768
Or
Use the latest version of PowerShell 7+ as the runtime version (highly recommended).
- Build Help error:
New-ExternalHelp : The term 'New-ExternalHelp' is not recognized as the name of a cmdlet, function, script file, or operable program. Check the spelling of the name, or if a path was included, verify that the path is correct and try again.
.
To solve this error, install PlatyPS module by running the command:
Install-Module -Name PlatyPS