Diagram

If you’re using Azure Logic Apps to disable users in Azure AD with the Azure AD connector and encounter a 403 Forbidden error, it might be because the user is part of a role-assignable group. Members of these groups are considered highly privileged.

As a result, your Logic App lacks the necessary permissions to disable these users via the Azure AD connector - even if your Azure AD account has an RBAC role such as Privileged Authentication Administrator or Global Administrator.

Unfortunately, we can’t add Graph permissions directly to the Logic App. But don’t worry, with some Jedi mind tricks, you can get around it! 🧙

Application Configuration

First, register a new application and define permissions to access and interact with Azure AD via the Graph API. Here’s how to do it:

  1. In the portal, navigate to App registrations > New registration.
  2. Give it a memorable name and select Register.
  3. Note the Application (client) ID for later use.

Create app registration

Once the app is registered, add a new client secret and the required API permissions as follows:

Adding a client secret

  1. Select your application.
  2. Navigate to Certificates & secrets > Client secrets > New client secret > Add.
  3. Note the Secret value for later use.

Configuring permissions

Next, configure permissions for the application. Review these permissions and others in the Graph documentation  here.

  1. Navigate to API permissions > Add a permission.
  2. Select Microsoft Graph > Application permissions and add the following permissions:
    • Directory.ReadWrite.All
    • Group.ReadWrite.All
    • User.EnableDisableAccount.All
    • User.ReadWrite.All
  3. Select Grant admin consent for Default Directory and confirm.

Your application is now configured. To enhance security, let’s add the client secret to Key Vault.

Azure Key Vault Configuration

Key Vault is an Azure key management solution that provides secure storage and management of keys, certificates, and secrets. Here’s how to create a Key Vault:

  1. In the portal, navigate to Key vaults > Create.
  2. Select your Resource group.
  3. Give it a memorable name and select your region.
  4. Standard pricing tier should suffice.
  5. Navigate to Access Policy and set permission model to Azure role-based access control.
  6. Create the Key Vault.

Now that the Key Vault is created, add the application client secret as follows:

  1. Assign yourself permission to the Key Vault (e.g., Key Vault Administrator), see all available roles  here.
  2. Navigate to your Key Vault.
  3. Navigate to Secrets > Generate/import.
  4. Give it a memorable name.
  5. Paste your client secret value from earlier.
  6. Select Create.

Now that your client secret is secured, create your Logic App and put all the pieces together!

Logic App Configuration

Create a new Logic App resource. Here’s how:

  1. Select your Resource group.
  2. Select Create, search for Logic App, and select Create.
  3. Select your preferred SubscriptionResource group, and Region.
  4. Give it a memorable name.
  5. Select Review + create > Create.

  1. Navigate to your new Logic App.
  2. Select Identity > Enable System assigned managed identity.
  3. Select Azure role assignments > Add role assignment
    • Scope: Key Vault
    • Subscription: Select your subscription
    • Resource: Select the Key Vault we created earlier
    • Role: I will be using Key Vaults Secrets User, but you can choose any sufficient role from the documentation  here.

Workflow Configuration

  1. Navigate to your new Logic App.
  2. Select Logic app designer, you can start with a template or select Blank Logic App.
  3. Add the Azure Key Vault Get secret action
    • Give your connection a memorable name
    • Authentication type: Managed identity
    • Vault Name: Enter the name of your Key Vault resource

After the API connection is authenticated, select the name of your secret.

Add an HTTP action and configure like so:

  • Method: POST
  • URI (Make sure to remove the braces and populate with your values):
  • Headers:
    • Content-Type: application/x-www-form-urlencoded
  • Body (Make sure to remove the braces and populate with your values):
    • client_id={INSERT-YOUR-APPLICATION-CLIENT-ID}&scope=https%3A%2F%2Fgraph.microsoft.com%2F.default&client_secret={INSERT-YOUR-APPLICATION-SECRET-VALUE}&grant_type=client_credentials

Now the part you’ve been waiting for - disabling the user!

Add another HTTP action, and configure like so:

Select Add new parameter > Authentication:

  • Authentication type: Raw
  • Value: access_token (from Parse JSON action)

  • Save your workflow and Run Trigger to test.

  • Verify the account was disabled.

Thank you so much for taking the time to read my blog post. I hope you found it informative and helpful. If you have questions or feedback, please don’t hesitate to reach out.