just want to know if and how I can parse a HTTP response with a dynamic name in a JSON? I used the Azure Management API to receive the managed identities (system- and user assigned managed identities) to receive all managed identities. With a foreach I am iterating the results.
If a resource has a system assigned managed identity and user assigned managed identity, the response looks like this:
{
"principalId": "<principalId1>",
"tenantId": "<tenantId>",
"type": "SystemAssigned, UserAssigned",
"userAssignedIdentities": {
"/subscriptions/<subscriptionId>/resourcegroups/<resourceGroupName>/providers/Microsoft.ManagedIdentity/userAssignedIdentities/<userAssignedIdentitiesName>": {
"principalId": "<principalId2>",
"clientId": "<clientId>"
}
}
}
Now, I would like to get the <principalId2>.
Unfortunately, the Name of the object is dynamic related to the scope of the resource /subscriptions/<subscriptionId>/resourcegroups/<resourceGroupName>/providers/Microsoft.ManagedIdentity/userAssignedIdentities/<userAssignedIdentitiesName>.
How can I parse the JSON to receive the needed <principalId2>?
For all other responses I can easily use the Data operations Parse JSON with the payload I inserted from the HTTP response.
Is there a way to use a wildcard? Otherwise, could I somehow just select the first object of userAssignedIdentities to receive the needed value?



Parse Jsonare supported. Is looks like this/subscriptions/<subscriptionId>/resourcegroups/<ResourceGroupName/providers/Microsoft.ManagedIdentity/userAssignedIdentities/<userAssignedIdentitiesName>. Only thesubscriptionId,ResourceGroupNameanduserAssignedIdentitiesNameis dynamic.