Convert Figma logo to code with AI

Gerenios logoAADInternals

AADInternals PowerShell module for administering Azure AD and Office 365

1,329
218
1,329
16

Top Related Projects

Azure Command-Line Interface

Microsoft Authentication Library (MSAL) for .NET

A collection of Azure AD/Entra tools for offensive and defensive security purposes

Quick Overview

AADInternals is a PowerShell module for managing Azure Active Directory (Azure AD) and Microsoft 365. It provides a comprehensive set of tools for administrators and security professionals to perform various tasks, including user management, security assessments, and advanced Azure AD operations.

Pros

  • Offers a wide range of functionalities for Azure AD and Microsoft 365 management
  • Provides access to features not available in official Microsoft tools
  • Regularly updated with new features and improvements
  • Extensive documentation and community support

Cons

  • Requires advanced knowledge of Azure AD and PowerShell
  • Some features may pose security risks if used improperly
  • Not officially supported by Microsoft
  • May require frequent updates to maintain compatibility with Azure AD changes

Code Examples

  1. Connecting to Azure AD:
# Import the module
Import-Module AADInternals

# Connect to Azure AD
$tenant = "contoso.com"
$cred = Get-Credential
Connect-AADInternal -Tenant $tenant -Credentials $cred
  1. Retrieving user information:
# Get user details
$userPrincipalName = "john.doe@contoso.com"
Get-AADIntUser -UserPrincipalName $userPrincipalName
  1. Performing a security assessment:
# Run a security assessment on the tenant
Get-AADIntTenantDetails | Get-AADIntTenantSecurityAssessment

Getting Started

To get started with AADInternals:

  1. Install the module from PowerShell Gallery:

    Install-Module AADInternals
    
  2. Import the module:

    Import-Module AADInternals
    
  3. Connect to your Azure AD tenant:

    $tenant = "yourtenant.onmicrosoft.com"
    $cred = Get-Credential
    Connect-AADInternal -Tenant $tenant -Credentials $cred
    
  4. Start using AADInternals cmdlets to manage your Azure AD environment. Refer to the project's documentation for detailed usage instructions and available commands.

Competitor Comparisons

Azure Command-Line Interface

Pros of azure-cli

  • Official Microsoft tool with comprehensive Azure service coverage
  • Regular updates and extensive documentation
  • Cross-platform support (Windows, macOS, Linux)

Cons of azure-cli

  • Larger footprint and more complex installation process
  • Primarily focused on Azure services, less specialized for AAD-specific tasks
  • Steeper learning curve for users unfamiliar with Azure ecosystem

Code Comparison

AADInternals:

# Get access token for Azure AD Graph API
$token = Get-AADIntAccessTokenForAADGraph
# Get user information
Get-AADIntUser -AccessToken $token -UserPrincipalName user@domain.com

azure-cli:

# Log in to Azure
az login
# Get user information
az ad user show --id user@domain.com

Summary

AADInternals is a PowerShell-based toolkit specifically designed for Azure Active Directory (AAD) management and security testing. It offers specialized AAD-focused functionalities and is lightweight.

azure-cli is Microsoft's official command-line interface for managing Azure resources. It provides broader Azure service coverage but may be less focused on AAD-specific tasks. It offers cross-platform support and extensive documentation.

The choice between these tools depends on the specific use case, with AADInternals being more suitable for AAD-centric tasks and azure-cli for general Azure management.

Microsoft Authentication Library (MSAL) for .NET

Pros of microsoft-authentication-library-for-dotnet

  • Official Microsoft library for Azure AD authentication
  • Extensive documentation and support from Microsoft
  • Seamless integration with other Microsoft services and APIs

Cons of microsoft-authentication-library-for-dotnet

  • Limited to .NET framework and languages
  • May have a steeper learning curve for non-Microsoft developers
  • Less flexibility for custom authentication scenarios

Code Comparison

microsoft-authentication-library-for-dotnet:

IPublicClientApplication app = PublicClientApplicationBuilder
    .Create(clientId)
    .WithAuthority(AzureCloudInstance.AzurePublic, tenantId)
    .Build();

AuthenticationResult result = await app.AcquireTokenInteractive(scopes).ExecuteAsync();

AADInternals:

$token = Get-AADIntAccessTokenForAADGraph -Resource "https://graph.windows.net" -SaveToCache
$user = Get-AADIntUser -UserPrincipalName "user@contoso.com" -AccessToken $token

The microsoft-authentication-library-for-dotnet example shows acquiring a token using the official SDK, while AADInternals demonstrates a more direct approach to token acquisition and user information retrieval using PowerShell cmdlets.

A collection of Azure AD/Entra tools for offensive and defensive security purposes

Pros of ROADtools

  • Written in Python, which may be more accessible for some users
  • Includes a GUI (ROADrecon) for visualizing Azure AD data
  • Offers broader functionality beyond just Azure AD, including Azure resources

Cons of ROADtools

  • Less focused on specific Azure AD internals compared to AADInternals
  • May require more setup and dependencies due to its broader scope
  • Documentation is less extensive than AADInternals

Code Comparison

ROADtools:

from roadtools.roadlib import ROADClient
client = ROADClient()
client.get_tokens()
result = client.get_user('user@example.com')

AADInternals:

Import-Module AADInternals
Get-AADIntAccessTokenForAADGraph -SaveToCache
Get-AADIntUser -UserPrincipalName user@example.com

Both tools provide similar functionality for authenticating and retrieving user information, but with different syntax and approaches. ROADtools uses Python and object-oriented programming, while AADInternals uses PowerShell cmdlets. The choice between them may depend on the user's familiarity with the respective languages and their specific use case in Azure AD and Azure resource management.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

AADInternals

AADInternals is PowerShell module for administering Azure AD and Office 365

For details, please visit https://aadinternals.com/aadinternals

Installation

Run the following PowerShell command to install

Install-Module AADInternals