New Contributor II
New Contributor II

A Little Background

In 2017, Jamf released an integration with Microsoft Endpoint Manager’s (formerly Intune) Partner Device Management (PDM) API. This API allows Jamf Pro to send inventory data for managed computers to Microsoft Endpoint Manager, where compliance is then calculated using Microsoft Endpoint Manager’s Compliance Policies.

In order for Jamf Pro to send data to Microsoft Endpoint Manager, computers must be registered to Azure AD using Company Portal, and a jamf agent (JamfAAD) must collect and maintain an active user session token. Organizations seeking to use the PDM integration must guide end users through this registration flow.

The following document addresses best practices for registration, including configuration of the JamfAAD agent, Azure AD SSO Extension, using policies to guide the user, and tracking registrations via Extension Attributes.

Configuring the JamfAAD agent


JamfAAD must prompt the user to sign in with their Azure AD credentials in order to obtain a user session token. To do this, JamfAAD leverages MSAL, and defaults to MSAL’s ASWebAuthenticationSessionRequest. ASWebAuthenticationSessionRequest calls on the user’s default browser (if that browser supports ASWebAuth) to handle a sign in to

However, due to the variability introduced by supporting multiple browsers (ASWebAuth is supported by Chrome, Edge, and Safari), the default browser can often be a point of failure for conditional access registrations.

In Jamf Pro 10.38 and higher, an optional configuration was added to use MSAL’s WKWebView instead. This leverages macOS’s built in WebView to present the Azure AD login. This setting is recommended to all environments that are compatible with WKWebView (note some forms of MFA, like hardware tokens, are not supported by WKWebView at time of writing).

To use UseWKWebView, push this PLIST out to the preference domain.

Screenshot 2022-09-23 at 1.57.23 PM.png



Retry Logic

The JamfAAD agent attempts to refresh the user’s session token when the LaunchAgent loads, and additionally once every two hours. This refresh is performed using an MSAL silent authentication flow. If this silent authentication fails to obtain a user session token for any reason, JamfAAD will fall back to an interactive MSAL flow, resulting in the user being prompted to sign in with their Azure AD credentials again.

In many scenarios, this is JamfAAD helpfully doing its job. For example, if the user’s Azure AD credentials have been changed, JamfAAD will need to prompt the user for their new Azure AD credentials. JamfAAD might also prompt for the user to sign in if a conditional access policy requires interactive sign-ins (this may be a pain point for end users, and conditional access policies should be configured to not force re-authentication if possible).

However, JamfAAD may also fail to retrieve a user’s session token in a scenario where the LaunchAgent loads but a stable network connection has not yet been established. This momentary lack of connectivity may result in JamfAAD falling back to the interactive flow, prompting the user to sign in again. This may manifest as the user having a JamfAAD prompt waiting for them every morning.

In Jamf Pro 10.27 and higher, JamfAAD can be configured to wait and retry a silent authentication a configurable number of times before falling back to an interactive flow. Configuring this retry logic to try again just a couple of times over a few minutes is enough to ensure users are not prompted due to network related timing issues. This setting is recommended for all environments. The retry wait and count settings can be adjusted if desired, but these default settings should cover the most common scenarios.

To configure retry wait and count, push this PLIST to the preference domain.



Azure AD SSO Extensions

In macOS 10.15, Apple rolled out their first iteration of SSO extensions. Microsoft has published their SSO extension, which uses Self Service on macOS, and Microsoft Authenticator on iOS. The SSO extension can handle authentication for any app that uses MSAL, or that supports redirect SSO extensions. Since JamfAAD uses MSAL, this means that the SSO extension can handle the JamfAAD sign-in prompts automatically. This reduces the registration flow to a single authentication in Company Portal.

Note: The SSO extension does not bypass MFA, if the JamfAAD sign in falls into a Conditional Access policy requiring MFA, the user will be prompted to sign in and complete MFA

Microsoft has published documentation on how to configure the Azure AD SSO extension in Jamf Pro here: Microsoft Enterprise SSO plug-in in Jamf Pro

In order to grant JamfAAD access to the SSO extension, must be added to the AppPrefixAllowList (step 5 in the Microsoft document). Here's an example plist.



Prompting Users to Register

To initiate the registration, the user must run the registration policy from Self Service. A policy that leverages osascript, JamfHelper, or other user notification tools can guide the user to execute the policy and provide some explanation of what is happening and why.

Here's a link to a script that leverages osascript to prompt the user to register from Self Service.



Tracking Registration

After users register, there are two things to look for on the computer itself to gauge whether or not the registration was successful:

  • Is there a Workplace Join key in the user’s Login Keychain
  • Was JamfAAD able to obtain the Azure AD ID of the user

Here's a link to an extension attribute that checks both.

The script can return one of four results:

     1. Registered

This signifies that the user has a WPJ certificate in their keychain, and JamfAAD has successfully obtained their Azure AD ID.

     2. WPJ Key present, JamfAAD PLIST missing

This signifies that the user has a WPJ certificate in their keychain, but JamfAAD has never run. This may indicate that the user was manually registered via Company Portal without jamfAAD calling the registration.

Machines in this state should run the registration policy in Self Service.

     3. WPJ Key present, AAD ID not acquired

This signifies that the user has a WPJ certificate in their keychain, but JamfAAD has not successfully obtained the Azure AD ID of the user. JamfAAD may try again to grab the AAD ID of the user within the next two hours.

This scenario may also be remediated by running /usr/local/jamf/bin/jamfaad gatherAADInfo on that machine as the logged in user.

Note: If this command is run as root, it will do more harm than good. If running from Jamf Pro, make sure to run it as the logged in user!

     4. Not Registered

This indicates that no WPJ certificate is present in the user’s login keychain. This indicates that either the machine has never been registered via Company Portal, or something has happened to the user’s login keychain. If the machine was previously registered, this may indicate a password reset was performed (password resets will most often result in the loss the existing login keychain).

Machines in this state should run the registration policy from Self Service.



This was originally posted to my personal GitHub, available here.


Contributor II

Good Job Buddy!

New Contributor

Good Article explaining Azure AD.  One question I have is, where did "AAD Registation State"  as a criteria in Smart Groups come from.  I don't seem to have that listed in my Jamf Pro.

New Contributor II

@bmargrave You have to create a computer extension attribute:

  1. Go to Settings > Computer Management > Extension attributes > "+ New"
  2. Name it and set the Script as the Input Type and insert the script.
  3. Now save it and check the id in the URL:
    example: "...computerExtensionAttributes.html?id=3&o=u"
  4. Afterwards create a new configuration profile or choose an existing > Extensions > "+ Add" 
  5. For "Allowed extension" set $EXTENSIONATTRIBUTE_X - in my example it is $EXTENSIONATTRIBUTE_3 .
  6. Don't forget to set the Extension Points to "Deny extension points and extensions" and select or add the ones you want to deny. Otherwise OneDrive doesn't sync and also other services could be affected.
    Screenshot 2022-11-16 at 12.09.46.png

After you created the extension attribute, you can use it as criteria for smart groups.


Contributor II

Good one..

New Contributor II


Where will I find the script to insert in EA?

New Contributor II


You can find it in Ben's GitHub repository.
HERE is the direct link to the script.

New Contributor III

Ok, now that I am finally using the "useWKWebView" profile / key, that solves the Safari web browser issue (and going down a rabbit hole of changing the default web browser....yikes), or even having to deal with a spawning web browser situation. With this profile/key, you are presented with a a single / clean sign in page and you sign in, and I see "Registered" now (after a recon)...

But I now see this "JCA wants to sign using key "Microsoft Workplace Join Key....."  I am just testing this on ADE / DEP Notify enroll to dial in the AAD registration, so I am already AAD/Intune registered. Maybe this is why, not sure.

So is there any way to not see this JCA popup, and, any way to keep testing this without necessarily deleting the registration in Intune, etc. thanks in advance...