This workflows allows for the automatic granting of secure tokens to the Jamf Pro Assigned user on a machine utilizing a known SecureToken Enabled administrator account
To have a user driven, automatic method of enabling the primary user on a machine with a SecureToken and have FileVault enabled with a method of enabling future accounts
With the Apple implementation of giving SecureTokens to accounts that do not have them, it requires the user to enter the credentials to the SecureToken enabled administrator account. This is obviously something that a system administrator would not want a user to know or do. Therefore we need a way of placing the SecureToken environment into a known state with known credentials be used in an automatically trigged method for assigning the user a SecureToken. Then reporting on that success.
For this first steps let's get rid of that pesky Apple SecureToken prompt since your users won't know your admin password. This can be done by using a custom config profile with the following information
Custom Settings
	Domain: com.apple.mcx
	Contents: cachedaccounts.askForSecureTokenAuthBypass=true
To setup some smart group scopings for Step 3 and 4 we must start retrieving the SecureToken list from the endpoint. This takes the form of an Extension Attribute. This takes the form of the following properties
- Name - SecureToken Status
- Data Type - String
- Input Type - Script
- Script - SecureTokenStatusEA.sh
Due to the limitation of not being able to do any funky regex on the Jamf pro side to check if the assigned user has a token. Therefore we need an EA. This EA uses an API call with Jamf to get the assigned user username, then checks that against the SecureToken enabled users on the machine. We can't use script parameters to get the API username and password unfortunately because it is an EA. The contents of the EA are below
- Name - Assigned User has SecureToken
- Data Type - String
- Input Type - Script
- Script - assignedUserFV2EnabledEA.sh
Note: You will need to add your Jamf Pro Server API username and password to the script for it to function
- When the user account creation is skipped during a pre-stage enrollment there are situations where the management account can be granted the first SecureToken. Once this secure token is granted it must be used to grant other tokens.
- There are other situations after a DEP enrollment or large major OS upgrade that can leave the machine with no SecureTokens. Therefore making grabbing thebe first one for a known administrator account even more important
- The FV2 authentication screen presents all users that have a SecureToken no matter if they are hidden or not, therefore it is extremely important to try and minimize the number accounts presented to the user at this screen to avoid confusion.
This implementation will take three stages. First, setting up the smart group for the policy. Second, adding the script to JAMF and explaining the script arguments. Third, the actual policy to run our script. Everything followed by some general comments about the script and explanations on why things are done the way they are.
- Name - Security - SecureToken - Machine Needs remediation
- Criteria
| And/Or | ( | Criteria | Operator | Value | ) | 
|---|---|---|---|---|---|
| Computer Group | member of | Group containing the computer you would like to target for the endgame | |||
| and | SecureToken Status | does not match regex | [.]*NAME_OF_ADMIN_ACCOUNT[.]* | ||
| and | Computer Group | member of | Group containing all MacOS 10.14+ Machines | ||
| and | Assigned User Has SecureToken | is not | True | 
- 
Name - enableHiddenAdminForFV2.sh
- 
Script - enableHiddenAdminForFV2.sh
- 
Options - Admin Username
- Admin Password
- Management Account Username
- Management Account Password
 
- General
- Name - Maintenance - SecureToken Machine Remediation
- Enabled - True
- Triggers
- Recurring Check-in
 
- Frequency - Ongoing
 
- Name - 
- Scripts
- Script - enableHiddenAdminForFV2.sh
- Priority - Before
- Parameters - Please will all the defined parameters in
 
- Script - 
- Maintenance
- Update Inventory - Enabled
 
- Scope
- Computer Group - Security - SecureToken - Machine Needs remediation
 
- Computer Group - 
# Attempting to remove the secure token from the account
if [[ $(sysadminctl -secureTokenOff $managementUser -password $managementPass -adminUser $adminUser -adminPassword $adminPass 2>&1 | grep -v "Done") ]]; then
        
	# If the removal fails using sysadminctl then nuke the account to get rid of the token
	jamf policy -event recreateManagementAccount
fiThere are documented cases I have found where the management account password I had defined can be used to grant a secure token to the admin account, but utilizing that same password to removing the token from the management account will not function. This leaves the only option of removing the SecureToken to be deleting the management account and recreating it. I will put the policy to update the management account in the remaining thoughts section of this readme.
Also why is there not an ! in front of the sysadminctl command in the if statement below?
Well, that's just how the return code for grep -v works. ¯_(ツ)_/¯
Well for this to work you are going to need to have the managment account password in a known state and have the cleartext password. Therefore you are going to need to preceed and follow line 41 with Jamf policy calls that set the password to a known state and then sets it back to a random state afterwards. Should look something like this:
... bleh bleh ...
# Setting the managment account to a known password
jamf policy -trigger setManagmentAccountToKnownPassword
# Enabling the secure token for the admin account
sysadminctl -secureTokenOn $adminUser -password $adminPass -adminUser $managementUser -adminPassword $managementPass
# Setting the mangement account back to a random password
jamf policy -trigger randomizeManagementAccountPassword
... bleh bleh ...These policy triggers would be tied to policies that utilize the Managment account administration payload to do their respective tasks.
Similar to Step 4 there are going to be multiple steps in getting this thing configured as well
- Name - Security - SecureToken - Ready for user token assignment
- Criteria
| And/Or | ( | Criteria | Operator | Value | ) | 
|---|---|---|---|---|---|
| Computer Group | member of | Group containing the computer you would like to target for the endgame | |||
| and | SecureToken Status | matches regex | [.]*NAME_OF_ADMIN_ACCOUNT[.]* | ||
| and | Computer Group | member of | Group containing all MacOS 10.14+ Machines | ||
| and | Assigned User Has SecureToken | is | False | 
- 
Name - enableUserUsingAdminForFV2.sh
- 
Script - enableUserUsingAdminForFV2.sh
- 
Options - Admin Username
- Admin Password
 
- General
- Name - Configuration - Enable User account with a Secure Token
- Enabled - True
- Triggers
- Login
 
- Frequency - Ongoing
- Client Side Restrictions
- Limit to Jamf Pro-assigned user - Enabled
 
- Limit to Jamf Pro-assigned user - 
 
- Name - 
- Scripts
- Script - enableUserUsingAdminForFV2.sh
- Priority - Before
- Parameters - Please will all the defined parameters in
 
- Script - 
- Maintenance
- Update Inventory - Enabled
 
- Scope
- Computer Group - Security - SecureToken - Ready for user token assignment
 
- Computer Group - 
Note - the cancel button is variable which is elaborated upon in the next note, also you can edit the text to be whatever you want
In my organization I have a receipt directory in the /Library/Contoso/Receipts. Therefore first off, if this directory does not exist then the touch command will fail and you are gonna start getting failures in your Jamf Pro Server reports on the execution of this policy. Also the one time option to cancel will not be a thing. The user will have the ability to cancel as many times as they want. This is not something we wanted, hence I added in the receipt. One Cancel, that's all you get. You can tailor this to do what you want.
This last one is thankfully a little easier! Now that we have our user with a SecureToken we can look at enabling FileVault 2. The general setup for this is below. Feel free to customize it using your own secret sauce. Not mentioned below is that you will also want to include a FileVault 2 Key Escrow configuration profile to instruct the machine to pass the FileVault 2 recovery key to your Jamf Pro Server.
- Name - Security - SecureToken - Assigned User has Token
- Criteria
| And/Or | ( | Criteria | Operator | Value | ) | 
|---|---|---|---|---|---|
| Assigned User Has SecureToken | is | True | 
Note - The smart group criteria is VERY flexible and probably needs more client disk state validation as defined in Jamf FV2 Technical documentation
- General
- Name - Configuration - Enable FileVault 2 Configuration on Next login
- Enabled - True
- Triggers
- Recurring Check-in
 
- Frequency - Once per Computer
 
- Name - 
- Disk Encryption
- Action - Apple Disk Encryption Configuration
- Disk Encryption Configuration - Contoso Disk Encryption Configuration (You'll need to make this under the Disk Encryption Settings)
- Require FileVault 2 - At Next Login(my personal preference)
 
- Action - 
- Scope
- Computer Group - Security - SecureToken - Assigned User has Token
 
- Computer Group - 
- User Interaction
- Complete Message - FileVault 2 has been enabled. Please restart to begin
 
- Complete Message - 
This policy and what it actually is both scoped to and what it really does is extremely environment dependent. I can only advise what I am intending for my own environment. Your mileage always will vary.
The policy I have is as follows, please use this as a template.
- General
- Name - Utility - Remove and re-create management account
- Enabled - True
- Triggers
- Custom
- recreateManagementAccount
 
 
- Custom
- Frequency - Ongoing
 
- Name - 
- Scripts
- Script - DeleteManagmentAccount.sh- Script contents are as follows
 #!/bin/bash sysadminctl -deleteUser MANAGEMENT_ACCOUNT_USERNAME -secure
- Priority - Before
 
- Script - 
- Local Accounts
- Create New Account - Selected
- Username - You management account username
- Password & Verify Password - You management account password
- Home Directory Location - /private/var/MANAGEMENT_ACCOUNT_USERNAME
- Allows the user to administer computer - Enabled
 
- Create New Account - 
- Scope
- All Computers
 
Have not had to deal with this personally yet, but to accomplish this it would be a combination of both using the passwd binary to change the password on the MacOS side, but then also a diskutil apfs changePassphrase BOOTDISK -user UUID to get the FileVault side changed as well. Also you will need to update all your script parameters
I have noticed some issues where the second login trigger will fail to launch in a timely manner after the second login due to Jamf's -randomDelay parameter being called by another login trigger. Therefore the creation of a script that is called by outset under the login-every-privileged config that calls the login Jamf policy trigger and nuking any process waiting with a -randomDelay would be the way to remediate this. I might write this script if I notice this issue more prevalent in my own environment
No, It's a filler name. Put your own company names here
The FV2 authentication screen only respects the accounts that have a SecureToken enabled on them on that local machine. In Lab situations whether you are binding you machines to LDAP/AD or using something like NoLo/Jamf Connect the FV2 authentication screen happnens before those products even start. Therefore upon a reboot/cold boot a brand new user to that machine will have no method of logging in. Hence, why you don't want to use FV2 in Lab situations
This method of encrypting those parameters is the best I am going to be able to do. If that does not work for you, then this workflow might not be for you.
Check this out: https://travellingtechguy.eu/final-wrap-up-on-secure-tokens/
Also there is Apple's documentation: https://help.apple.com/deployment/macos/?lang=en#/apd8faa99948
So basically the Jamf implementation of enabling filevault using a policy with a disk encryption configuration appears to be defunct in the early versions of the MacOS Catalina betas. This causes Filevault to not enable silently along with other issues. I recommend you investigate and test your filevault enablement with the new MacOS versions. Currently (10.15b2) this script and workflow behaves as is intended.
