Hi!
In this article, I will show you how you can exploit a virtual machine associated with a Managed Identity. To leverage this attack, we will use the LAVA – Azure Exploitation framework.
In the first step, we will execute a command to list all the machines hosted in the Azure subscription. The goal of this action is to identity which machine is configured with a Managed Identity. In the example below, we can see the virtual machine max01 configured with a Managed Identity (SystemAssigned).
data:image/s3,"s3://crabby-images/61faa/61faa083ca3e7a1d34b60994a12597ef093a8a02" alt=""
In the second step, we can see the virtual machine max01 associated with a privilege role. In this example, the privileged role associated with the identity of the max01 virtual machine is owner of the Azure subscription!
data:image/s3,"s3://crabby-images/8429b/8429bdcb684e9c7f58484688fa38c0566cf1213e" alt=""
In the third step, we will leverage the « Run Command » feature, to execute a call to the metadata endpoint and retrieve the access token used by the Managed Identity feature. By default all the commands executed with the « Run Command » feature are executed as root!
data:image/s3,"s3://crabby-images/437bc/437bc735cd93456c67e43084e1d8978b7a5f4517" alt=""
data:image/s3,"s3://crabby-images/5b301/5b30184f2658ad7923aa845878881b2ba503d1d5" alt=""
In the last step of this article, we will use the token retrieved during the third step and usurp the identity of the virtual machine max01 to run a command to list the subscriptions or the ressource groups. With the owner role associated to the managed identity, a malicious attacker could leverage this attack to create, modify or delete any resources hosted in this Azure Subscription.
data:image/s3,"s3://crabby-images/ee0c1/ee0c12cdc620650409693f30f71e1997e6434685" alt=""
data:image/s3,"s3://crabby-images/45c8a/45c8a41df751b2a1bd3f4c9c9d0607535e1ea17a" alt=""
Maxime.