AzureRT is a Powershell module implementing various cmdlets to interact with Azure and Azure AD from an offensive perspective.
Helpful utilities dealing with access token based authentication, switching from Az
to AzureAD
and az cli
interfaces, easy to use pre-made attacks such as Runbook-based command execution and more.
This toolkit brings lots of various cmdlets. This section highlights the most important & useful ones.
Typical Red Team / audit workflow starting with stolen credentials can be summarised as follows:
Credentials Stolen -> Authenticate to Azure/AzureAD -> find whether they’re valid -> find out what you can do with them
The below cmdlets are precisely suited to help you follow this sequence:
Connect-ART
– Offers various means to authenticate to Azure – credentials, PSCredential, tokenConnect-ARTAD
– Offers various means to authenticate to Azure AD – credentials, PSCredential, tokenGet-ARTWhoami
– When you authenticate – run this to check whoami and validate your accessGet-ARTAccess
– Then, when you know you have access – find out what you can do & what’s possible by performing Azure situational awarenessGet-ARTADAccess
– Similarly you can find out what you can do scoped to Azure AD.Cmdlets implemented in this module came helpful in following use & attack scenarios:
Az
to AzureAD
and back again.Az
, AzureAD
, Microsoft.Graph
and az cli
at the same timeThis module depends on Powershell Az
and AzureAD
modules pre-installed. Microsoft.Graph
and az cli
are optional but nonetheless really useful. Before one starts crafting around Azure, following commands may be used to prepare one’s offensive environment:
Install-Module Az -Force -Confirm -AllowClobber -Scope CurrentUser
Install-Module AzureAD -Force -Confirm -AllowClobber -Scope CurrentUser
Install-Module Microsoft.Graph -Force -Confirm -AllowClobber -Scope CurrentUser # OPTIONAL
Install-Module MSOnline -Force -Confirm -AllowClobber -Scope CurrentUser # OPTIONAL
Install-Module AzureADPreview -Force -Confirm -AllowClobber -Scope CurrentUser # OPTIONAL
Install-Module AADInternals -Force -Confirm -AllowClobber -Scope CurrentUser # OPTIONAL
Import-Module Az
Import-Module AzureAD
Even though only first two modules are required by AzureRT
, its good to have others pre-installed too.
Then to load this module, simply type:
PS> . .\AzureRT.ps1
The module will be gradually receiving next tools and utilities, naturally categorised onto subsequent kill chain phases.
Every cmdlet has a nice help message detailing parameters, description and example usage:
PS C:> Get-Help Connect-ART
Currently, following utilities are included:
Get-ARTWhoami
– Displays and validates our authentication context on Azure
, AzureAD
, Microsoft.Graph
and on AZ CLI
interfaces.Connect-ART
– Invokes Connect-AzAccount
to authenticate current session to the Azure Portal via provided Access Token or credentials. Skips the burden of providing Tenant ID and Account ID by automatically extracting those from provided Token.Connect-ARTAD
– Invokes Connect-AzureAD
(and optionally Connect-MgGraph
) to authenticate current session to the Azure Active Directory via provided Access Token or credentials. Skips the burden of providing Tenant ID and Account ID by automatically extracting those from provided Token.Connect-ARTADServicePrincipal
– Invokes Connect-AzAccount
to authenticate current session to the Azure Portal via provided Access Token or credentials. Skips the burden of providing Tenant ID and Account ID by automatically extracting those from provided Token. Then it creates self-signed PFX certificate and associates it with Service Principal for authentication. Afterwards, authenticates as that Service Principal to AzureAD and deassociates that certificate to cleanupGet-ARTAccessTokenAzCli
– Acquires access token from az cli, via az account get-access-token
Get-ARTAccessTokenAz
– Acquires access token from Az module, via Get-AzAccessToken
.Get-ARTAccessTokenAzureAD
– Gets an access token from Azure Active Directory. Authored by Simon Wahlin, @SimonWahlinGet-ARTAccessTokenAzureADCached
– Attempts to retrieve locally cached AzureAD access token (https://graph.microsoft.com), stored after Connect-AzureAD
occurred.Remove-ARTServicePrincipalKey
– Performs cleanup actions after running Connect-ARTADServicePrincipal
Get-ARTAccess
– Performs Azure Situational Awareness.Get-ARTADAccess
– Performs Azure AD Situational Awareness.Get-ARTTenants
– List Tenants available for the currently authenticated user (or the one based on supplied Access Token)Get-ARTDangerousPermissions
– Analyzes accessible Azure Resources and associated permissions user has on them to find all the Dangerous ones that could be abused by an attacker.Get-ARTResource
– Authenticates to the https://management.azure.com using provided Access Token and pulls accessible resources and permissions that token Owner have against them.Get-ARTRoleAssignment
– Displays a bit easier to read representation of assigned Azure RBAC roles to the currently used Principal.Get-ARTADRoleAssignment
– Displays Azure AD Role assignments on a current user or on all Azure AD users.Get-ARTADScopedRoleAssignment
– Displays Azure AD Scoped Role assignments on a current user or on all Azure AD users, associated with Administrative UnitsGet-ARTRolePermissions
– Displays all granted permissions on a specified Azure RBAC role.Get-ARTADRolePermissions
– Displays all granted permissions on a specified Azure AD role.Get-ARTADDynamicGroups
– Displays Azure AD Dynamic Groups along with their user Membership Rules, members count and current user membership statusGet-ARTApplication
– Lists Azure AD Enterprise Applications that current user is owner of (or all existing when -All used) along with their owners and Service PrincipalsGet-ARTApplicationProxy
– Lists Azure AD Enterprise Applications that have Application Proxy setup.Get-ARTApplicationProxyPrincipals
– Displays users and groups assigned to the specified Application Proxy application.Get-ARTStorageAccountKeys
– Displays all the available Storage Account keys.Get-ARTKeyVaultSecrets
– Lists all available Azure Key Vault secrets. This cmdlet assumes that requesting user connected to the Azure AD with KeyVaultAccessToken (scoped to https://vault.azure.net) and has “Key Vault Secrets User” role assigned (or equivalent).Get-ARTAutomationCredentials
– Lists all available Azure Automation Account credentials and attempts to pull their values (unable to pull values!).Get-ARTAutomationRunbookCode
– Invokes REST API method to pull specified Runbook’s source code.Get-ARTAzVMPublicIP
– Retrieves Azure VM Public IP addressGet-ARTResourceGroupDeploymentTemplate
– Displays Resource Group Deployment Template JSON based on input parameters, or pulls all of them at once.Get-ARTAzVMUserDataFromInside
– Retrieves Azure VM User Data from inside of a VM by reaching to Instance Metadata endpoint.Add-ARTADGuestUser
– Sends Azure AD Guest user invitation e-mail, allowing to expand access to AAD tenant for the external attacker & returns Invite Redeem URL used to easily accept the invitation.Set-ARTADUserPassword
– Abuses Authentication Administrator
Role Assignment to reset other non-admin users password.Add-ARTUserToGroup
– Adds a specified Azure AD User to the specified Azure AD Group.Add-ARTUserToRole
– Adds a specified Azure AD User to the specified Azure AD Role.Add-ARTADAppSecret
– Add client secret to the Azure AD Applications. Authored by Nikhil Mittal, @nikhil_mittInvoke-ARTAutomationRunbook
– Creates an Automation Runbook under specified Automation Account and against selected Worker Group. That Runbook will contain Powershell commands to be executed on all the affected Azure VMs.Invoke-ARTRunCommand
– Abuses virtualMachines/runCommand
permission against a specified Azure VM to run custom Powershell command.Update-ARTAzVMUserData
– Modifies Azure VM User Data script through a direct API invocation.Invoke-ARTCustomScriptExtension
– Creates new or modifies Azure VM Custom Script Extension leading to remote code execution.garak checks if an LLM can be made to fail in a way we don't…
Vermilion is a simple and lightweight CLI tool designed for rapid collection, and optional exfiltration…
ADCFFS is a PowerShell script that can be used to exploit the AD CS container…
Tartufo will, by default, scan the entire history of a git repository for any text…
Loco is strongly inspired by Rails. If you know Rails and Rust, you'll feel at…
A data hoarder’s dream come true: bundle any web page into a single HTML file.…