- Addresses Issue 139
brandingBannerDisplayText=false
not working (thanks for the report, @seaneldridge7!)
Thanks for the fix, @drtaru! Pull Request No. 140
- Addressed an issue where icons were not displaying (thanks, @bartreardon!)
- Updated Vimeo ID
- Corrected omission of [SYM-Helper] for
moveableInProduction
- Updated "Microsoft Office 365" to "Microsoft 365"
- Added OS Build number to webhook output Pull Request No. 124; thanks, @drtaru!
- Changed filepath validation test from
-f
(i.e., "True if file exists and is a regular file") to -e
(i.e., "True if file exists (regardless of type)."); thanks for the inspiration, @mrmte! Issue 19; thanks for the code suggestion, @bartreardon!
- Updates to
README.md
, CONTRIBUTORS.md
and CONTRIBUTING.md
Pull Request No. 128; thanks, @robjschroeder!
- Refactored the way
brandingBanner
variable is checked Pull Request No. 131; thanks, @drtaru!
- Increased minimum required version of swiftDialog to
2.4.0.4750
- Leveraged the new
listitem: subtitle
option with a dedicated subtitle
field in policyJSON
- Corrected misspelling of "policies" in log entries Issue No. 134; thanks, @Honestpuck!
- Updated
brandingBanner
to image by benzoix on Freepik
- 🔥 Breaking Change for users of Setup Your Mac prior to
1.13.0
🔥
- Removed
setupYourMacPolicyArrayIconPrefixUrl
(in favor using the fully qualified domain name of the server which hosts your icons)
- Added [SYM-Helper] to identify variables which can be configured in SYM-Helper (0.8.0)
- Updated sample banner image (Image by pikisuperstar on Freepik)
- Added
overlayoverride
variable to dynamically override the overlayicon
, based on which Configuration is selected by the end-user (Pull Request No. 111; thanks yet again, @drtaru!)
- Modified the display of support-related information (including adding
supportTeamWebsite
(Addresses Issue No. 97; thanks, @theahadub!))
- Adjustments to Completion Actions (including the
wait
flavor; thanks for the heads-up, @Tom!)
- Updated Microsoft Teams filepath validation
- Add position prompt (Addresses Issue No. 120; thanks for the suggestion, @astrugatch! Pull Request No. 121; thanks, @drtaru! This has to be your best one yet!)
- Corrections to "Continue" button after Network Quality test Pull Request No. 115; thanks, @delize!
- Added a failure indication when a "Local" validation trigger does not exist in the main script (Pull Request No. 117; thanks for another one, @drtaru!)
- Restored logging of
jamfProPolicyNameFailures
- Updated
if … then
statements when disabling the "Continue" button in the User Input "Welcome" dialog until Dynamic Download Estimates have complete (Pull Request No. 115; thanks, @delize!)
- Better WelcomeMessage logic and variable handling (Pull Request No. 101; thanks big bunches, @GadgetGeekNI!)
- Added
-L
to curl
command when caching banner images (thanks for the suggestion, @bartreardon!)
- Added
swiftDialogMinimumRequiredVersion
variable to more easily track the minimum build. (Pull Request No. 98; thanks, @GadgetGeekNI!)
- Hide unused Support variables (Pull Request No. 99; thanks again, @GadgetGeekNI!)
- Added Pre-flight Check: Validate
supportTeam
variables are populated (Pull Request No. 100; thanks for another one, @GadgetGeekNI!)
- Added a check for FileVault being enabled during Setup Assistant (for macOS 14 Sonoma) (Pull Request No. 96; thanks, Obi-@drtaru!)
- Added ability disable the "Continue" button in the User Input "Welcome" dialog until Dynamic Download Estimates have complete (Pull Request No. 93; thanks, @Eltord!)
- Added a check to account for if the
loggedInUser
returns in ALL CAPS (as this sometimes happens with SSO Attributes) (Pull Request No. 94; thanks for another one, @Eltord!)
- Added a Pre-flight Check for the running shell environment: Will exit gracefully if the shell does not match \bin\bash. (Pull Request No. 95; thanks — yet again — @drtaru!)
- Remove any default dialog file
- Reverted
mktemp
-created files to pre-SYM 1.12.1
behaviour
- Updated required version of swiftDialog to
2.3.2.4726
- Added
sleep "${debugModeSleepAmount}"
to recon
validation
toggleJamfLaunchDaemon
(during quitScript
function) based on completionActionOption
(Pull Request No. 89; thanks for another one, @TechTrekkie!)
- Updated minimum version of macOS to 12
- Corrected deletion of cached welcomeBannerImage
- Added permissions correction on ALL
mktemp
-created files (for swiftDialog 2.3.1
)
- Updated required version of swiftDialog to
2.3.1.4721
- Add version check to
dialogCheck
(Pull Request No. 67; thanks yet again, @drtaru!)
- Make
presetConfiguration
also apply to userInput
(Pull Request No. 63; thanks for another one, @rougegoat!)
- Fix for visual hiccup where
infobox
displays "Analyzing input …" if configurationDownloadEstimation
and promptForConfiguration
are both set to false
(Pull Request No. 69; thanks yet again, @rougegoat!)
- Added networkQuality check for macOS Sonoma 14
- Formatting updates
- Updated Palo Alto GlobalProtect icon hash
- Changed "Restart Attended" Completion Action one-liner (Addresses Issue No. 71; thanks, @master-vodawagner!)
- Delay the removal of
overlayicon
(Addresses Issue No. 73; thanks, @mani2care!)
- Added
reconOption
prompts for realname
and email
(Addresses Issue No. 52; thanks for the suggestion @brianhm; thanks for the code, @Siggloo!)
- Changed dialog heights to percentages
- Auto-cache / auto-remove a hosted welcomeBannerImage (Addresses Issue No. 74
- Added a
welcomeDialog
option of messageOnly
(Addresses Issue No. 66; thanks for the suggestion, @ryanasik)
- Reverted "Restart Attended" Completion Action one-liner (Unaddresses Issue No. 71; sorry, @master-vodawagner)
- Set newly added email address to required (regex courtesy of @bartreardon) (Addresses Issue No. 75; thanks for the suggestion, @ryanasik)
- Added code to pre-fill user's full name (Addresses Issue No. 76; thanks for the suggestion, @ryanasik)
- Reverted dialog heights to pixels
- Updated Vimeo video ID
- Updated
serialNumber
code (with special thanks to @Eltord for saving each and every user 0.0.6
seconds)
- Added
suppressReconOnPolicy
variable; when set to true
, a -forceNoRecon
flag when executing the run_jamf_trigger
function (Addresses Issue No. 79; thanks for the idea, @fitzwater-rowan; thanks for yet another PR, @rougegoat!)
- Added "Install Buffers" to each Configuration to include installation time of packages (Addresses Issue No. 78; thanks, @Eltord!
- Added permissions correction on
mktemp
-created files (for swiftDialog 2.3
)
- Updated required version of swiftDialog to
2.3.0.4718
Release-specific Blog Post
- Updates for
swiftDialog
2.2
- Required
selectitems
- New
activate
command to bring swiftDialog to the front
- Display Configurations as radio buttons
- Report on RSR version (if applicable) Pull Request No. 50 thanks @drtaru!)
- Specify a Configuration as Parameter
11
(Pull Request No. 59; thanks big bunches, @drtaru!. Addresses Issue No. 58; thanks for the idea, @nunoidev!)
- Configuration Names and Descriptions as variables (Pull Request No. 60; great idea! thanks, @theadamcraig!)
- Consolidated Jamf Pro-related webHookMessage variables; Set "Additional Comments" to "None" when there aren't any failures
Release-specific Blog Post
- Removed "(beta)" from Dynamic Download Estimates
- Added
promptForBuilding
and promptForDepartment
to match other prompts for Welcome Screen (Pull Request No. 55; thanks @robjschroeder!)
- Rearranged "Pre-flight Check: Validate Logged-in System Accounts"
- Eliminated a visual "glitch" when
promptForConfiguration
is false
and configurationDownloadEstimation
is true
(Sort of addresses Issue No. 56; thanks for the heads-up, @rougegoat!)
- Eliminated the visual "glitch" when
welcomeDialog
is false
Release-specific Blog Post
- 🆕 Dynamic Download Estimates (Addresses Issue No. 7; thanks for the idea, @DevliegereM; heavy-lifting provided by @bartreardon!)
- Manually set
configurationDownloadEstimation
within the SYM script to true
to enable
- New
calculateFreeDiskSpace
function will record free space to scriptLog
before and after SYM execution
- Compare before and after free space values via:
grep "free" $scriptLog
- Populate the following variables, in Gibibits (i.e., Total File Size in Gigabytes * 7.451), for each Configuration:
configurationCatchAllSize
configurationOneSize
configurationTwoSize
configurationThreeSize
- Specify an arbitrary value for
correctionCoefficient
(i.e., a "fudge factor" to help estimates match reality)
- Validate actual elapsed time with:
grep "Elapsed" $scriptLog
- 🔥 Breaking Change for users of Setup Your Mac prior to
1.10.0
🔥
- Added
recon
validation, which must be used when specifying the recon
trigger (Addresses Issue No. 19)
- Standardized formatting of
toggleJamfLaunchDaemon
function
- Added logging while waiting for installation of
${jamflaunchDaemon}
- Limit the
loggedInUserFirstname
variable to 25
characters and capitalize its first letter (Addresses Issue No. 20; thanks @mani2care!)
- Added line break to
welcomeTitle
and welcomeBannerText
- Replaced some generic "Mac" instances with hardware-specific model name (thanks, @pico!)
- Replaced
verbose
Debug Mode code with outputLineNumberInVerboseDebugMode
function (thanks, @bartreardon!)
- Removed dependency on
dialogApp
- Check
bannerImage
and welcomeBannerImage
(Pull Request No. 22 AND Pull Request No. 24 thanks @amadotejada!)
- A "raw" unsorted listing of departments — with possible duplicates — is converted to a sorted, unique, JSON-compatible
departmentList
variable (Addresses Issue No. 23; thanks @rougegoat!)
- The selected Configuration now displays in
helpmessage
(Addresses Issue No. 17; thanks for the idea, @master-vodawagner!)
- Disable the so-called "Failure" dialog by setting the new
failureDialog
variable to false
(Addresses Issue No. 25; thanks for the idea, @DevliegereM!)
- Added function to send a message to Microsoft Teams Pull Request No. 29 thanks @robjschroeder!)
- Added Building & Room User Input, Centralize User Input settings in one area Pull Request No. 26 thanks @rougegoat!)
- Replaced Parameter 10 with webhookURL for Microsoft Teams messaging (Pull Request No. 31 @robjschroeder, thanks for the idea @colorenz!!)
- Added an action card to the Microsoft Teams webhook message to view the computer's inventory record in Jamf Pro (Pull Request No. 32; thanks @robjschroeder!)
- Additional User Input Flags (Pull Request No. 34; thanks @rougegoat!)
- Corrected Dan's copy-pasta bug: Changed
--webHook
to --data
(Pull Request No. 36; thanks @colorenz!)
- Enable or disable any combination of the fields on the Welcome dialog (Pull Request No. 37; thanks big bunches, @rougegoat!!)
- Moved various
shellcheck disable
codes sprinkled throughout script front-and-center to Line No. 2
- Add Remote Validation results of "Success" or "Installed" to update the List Item with "Installed" instead of "Running" (Pull Request No. 41; thanks @drtaru!)
- Option to disable Banner Text (Pull Request No. 42; thanks, @rougegoat!)
- Switch
policy -trigger
to policy -event
(Addresses Issue No. 38; thanks for looking out for us, @delize!)
- Resolves an issue when
promptForConfiguration
is NOT set to true
, the checkNetworkQualityConfigurations
function would display in the "Welcome" dialog (Addresses Issue No. 46; thanks, @jonlonergan!)
- Corrected capitalization of
networkQuality
- Added
trigger
validation
to "Elapsed Time" output
- Updated
webhookMessage
to include Slack functionality (Pull Request No. 48; thanks @iDrewbs!)
- Add button to computer record for Slack webhook (Pull Request No. 49; thanks @drtaru!)
- Fix Banner Text displaying when set to False (Pull Request No. 51; thanks @rougegoat!)
Release-specific Blog Post
- Previously installed apps with a
filepath
validation now display "Previously Installed" (instead of a generic "Installed"; Issue No. 13; thanks for the idea, @Manikandan!)
- Allow "first name" to correctly handle names in "Lastname, Firstname" format (Pull Request No. 11; thanks @meschwartz!)
- Corrected
PATH
(thanks, @Theile!)
Configuration
no longer displays in SYM's infobox
when welcomeDialog
is set to false
or video
(Addresses Issue No. 12; thanks, @Manikandan!)
- Updated icon hashes
toggleJamfLaunchDaemon
function (Pull Request No. 16; thanks, @robjschroeder!)
- Formatted policyJSON with Erik Lynd's JSON Tools
- Corrected an issue where inventory would be submitted twice (thanks, @Manikandan!)
Release-specific Blog Post
- Added
currentLoggedInUser
function to better validate loggedInUser
(Addresses Issue No. 2)
- Added new Microsoft Office 365 Remote Validation (Pull Request No. 3)
- Improved logging when
welcomeDialog
is video
or false
(Addresses Issue No. 4)
- Create
overlayicon
from Self Service's custom icon (thanks, @meschwartz!)
Release-specific Blog Post
- Introduces fully customizable "Configurations" (thanks, @drtaru!)
- Required: Minimum organizational apps (i.e., full disk encryption, endpoint security, VPN, communication tools, etc.)
- Recommended: Required apps and Microsoft Office
- Complete: Recommended apps, Adobe Acrobat Reader and Google Chrome
- Play video at Welcome dialog (Script Parameter
6
) by specifying video
(Addresses Issue No. 36)
- 🔥 Breaking Change for users of Setup Your Mac prior to
1.8.0
🔥
- To capture user input,
welcomeDialog
(Script Parameter 6
) must be set to userInput
- Addresses Issue No. 39 (thanks big bunches, @wako!)
- Addresses Issue No. 43 (thanks, @wako)
- Removed the following fields from the Welcome dialog
- Comment
- Select B
- Select C
Release-specific Blog Post
- Reordered Pre-Flight Check to not validate OS until AFTER Setup Assistant / Finder & Dock
- Added
disabled
option for requiredMinimumBuild
- Added check for Self Service's
brandingimage.png
(Addresses Issue No. 40)
- Pre-flight Check logging messages now saved to client-side log
- Addresses Issue No. 41
Release-specific Blog Post
- Addresses Issue No. 35
- Improves user-interaction with
helpmessage
under certain circumstances (thanks, @bartreardon!)
- Increased
debugMode
delay (thanks for the heads-up, @Lewis B!)
- Changed Banner Image (to something much, much smaller)
Release-specific Blog Post
- Adds compatibility for and leverages new features of swiftDialog
2.1
bannertext
helpmessage
infobox
progress
-related racing-stripes (which now require swiftDialog 2.1+
)
- Completion Actions
- Adjusted default code option (to hopefully help Mac Admins using an Enrollment Complete trigger [i.e.,
runAsUser
doesn't work too well when _mbsetupuser
is the logged-in user])
- Combined
listitem
steps for installation and validation (thanks, @roiegat!)
- Validate Operating System Version, Build and Outdated OS Action
- Addresses Issue No. 31
- Introduces the ability to specify a
requiredMinimumBuild
as Script Parameter 8
(thanks, @SirDrSpiderpig!)
- For example, to only allow macOS Ventura 13.2 (or later), specify:
22D
- Introduces Outdated OS Action
- Open Self Service to your OS update policy:
jamfselfservice://content?entity=policy&id=117&action=view
- Open Software Update (default):
/System/Library/CoreServices/Software Update.app
- Temporarily disables
jamf
binary check-in (thanks, @mactroll and @cube!)
- Purposely commented-out the code to re-enable the
jamf
binary; presumes the Mac will be restarted
- Separated "Global Variables" from "Dialog Variables" to allow for additional Script Parameters
- Improved Pre-flight Check messaging
- Introduces
verbose
as an option for Debug Mode
- Most useful when first deploying Setup Your Mac
Release-specific Blog Post
- Addresses Issue No. 21
- 🔥 Breaking Change 🔥 (for users of Setup Your Mac prior to
1.6.0
)
policy_array
's "path
" has been replaced with "validation
"
- 🆕 The
confirmPolicyExecution
function confirms if the policy needs to be executed for filepath
validations
- A validation of
None
always executes the Jamf Pro trigger when debug mode
is set to false
- 🆕 The
validatePolicyResult
function validates if the policy succeeded and the related service is running, based on the specified validation
option
- Feature-specific Blog Post
- Validation Options:
- {absolute path} (simulates pre-
1.6.0
behavior, for example: "/Applications/Microsoft Teams.app/Contents/Info.plist"
)
Local
(for validation within this script, for example: "filevault"
)
Remote
(for validation validation via a single-script Jamf Pro policy, for example: "symvGlobalProtect"
)
None
(for triggers which don't require validation, for example: recon
; always evaluates as successful)
- Enhanced policy logging options to address Issue No. 25
- Search for and comment-out:
eval "${jamfBinary} policy -trigger ${trigger}"
- Uncomment:
eval "${jamfBinary} policy -trigger ${trigger} -verbose | tee -a ${scriptLog}"
- Ensure
debug mode
is set to false
- Added Rosetta 2 policy execution and validation
- Enhanced Logging
Release-specific Blog Post
- Updates to "Pre-flight Checks"
- Moved section to start of script
- 🆕 Added additional check for Setup Assistant (for Mac Admins using an "Enrollment Complete" trigger)
Release-specific Blog Post
- 🆕 Prompt user for additional fields at Welcome dialog
- New fields are included in a single
welcomeJSON
variable (thanks for all your efforts and feedback, @drtaru and @Andrew!)
- Dynamic
reconOptions
based on user's input at the Welcome dialog
- Thanks for your patience, @remusache, @midiman1000, @erikmadams, @colorenz and @benphilware
- 🔥 Breaking Changes 🔥 (for users of Setup Your Mac prior to
1.5.0
)
- Script Parameter Reordering (sorry; I'll strive not to ever do this again)
- Parameter 4: Script Log Location [
/var/tmp/org.churchofjesuschrist.log
]
- Parameter 5: Debug Mode [
true
(default) | false
]
- Parameter 6: Welcome dialog [
true
(default) | false
]
- Parameter 7: Completion Action [
wait
| sleep
(with seconds) | Shut Down
| Shut Down Attended
| Shut Down Confirm
| Restart
| Restart Attended
(default) | Restart Confirm
| Log Out
| Log Out Attended
| Log Out Confirm
]
- Miscellaneous Improvements
- Moved code blocks and variables to better reflect the Welcome > Setup Your Mac > Failure workflow
- Random code clean-up
Release-specific Blog Post
- Significantly enhanced Completion Action options
- ✅ Addresses Issue 15 (thanks, @mvught, @riddl0rd, @iDrewbs and @master-vodawagner)
- 🎉 Dynamically set
button1text
based on the value of completionActionOption
(thanks, @jared-a-young)
- 🥳 Dynamically set
progresstext
based on the value of completionActionOption
(thanks, @iDrewbs)
- 🆕 Three new flavors: Shut Down, Restart or Log Out
- 🚨 Forced: Zero user-interaction
- Added brute-force
killProcess "Self Service"
- Added
hack
to allow Policy Logs to be shipped to Jamf Pro server
- ⚠️ Attended: Forced, but only after user-interaction (thanks, @owainiorwerth)
- Added
hack
to allow Policy Logs to be shipped to Jamf Pro server
- 👤 Confirm: Displays built-in macOS user-dismissible dialog box
- Sleep
- Wait (default)
- Improved Debug Mode behavior
- 🐛
DEBUG MODE |
now only displayed as infotext
(i.e., bottom, left-hand corner)
completionAction
informational-only with simple dialog box (thanks, @_____???)
- Swapped
blurscreen
for moveable
- General peformance increases
- Miscellaneous Improvements
- Removed
jamfDisplayMessage
function and reverted dialogCheck
function to use osascript
(with an enhanced error message)
- Replaced "Installing …" with "Updating …" for
recon
-flavored trigger
- Changed "Updating Inventory" to "Computer Inventory" for
recon
-flavored listitem
- Changed exit code to
1
when user quits "Welcome" screen
- Changed
welcomeIcon
URLs
- Changed URL for Harvesting Self Service icons screencast (thanks, @nstrauss)
Release-specific Blog Post
- Script Parameter Changes:
- ⚠️ Parameter 4:
debug
mode enabled by default
- 🆕 Parameter 7: Script Log Location
- 🆕 Embraced drastic speed improvements in 🚅
swiftDialog v2
💨
- Caffeinated script (thanks, @grahampugh!)
- Enhanced
wait
exiting logic
- General script standardization
- Modifications for swiftDialog v2 (thanks, @bartreardon!)
- Added I/O pause to
dialog_update_setup_your_mac
- Added
list: show
when displaying policy_array
- Re-ordered Setup Your Mac progress bar commands
- More specific logging for various dialog update functions
- Confirm Setup Assistant complete and user at Desktop (thanks, @ehemmete!)
- Added
setupYourMacPolicyArrayIconPrefixUrl
variable (thanks for the idea, @mani2care!)
- Removed unnecessary
listitem
icon updates (thanks, @bartreardon!)
- Output swiftDialog version when running in debug mode
- Updated URL for Zoom icon
- Replaced "ugly"
completionAction
if … then … else
with "more readabale" case
statement (thanks, @pyther!)
- Updated "method for determining laptop/desktop" (thanks, @acodega and @scriptingosx!)
- Additional tweaks discovered during internal production deployment
Release-specific Blog Post
- Adjust I/O timing (for policy_array loop)
Release-specific Blog Post
- Swap "Installing …" and "Pending …" status indicators (thanks, @joncrain)
- Updates for switftDialog v1.11.2
- Report failures in Jamf Pro Policy Triggers
- Added "dark mode" for logo (thanks, @mm2270)
- Added "compact" for
--liststyle
- Made Asset Tag Capture optional (via Jamf Pro Script Paramter 5)
- Changed
--infobuttontext
to --infotext
- Added
regex
and regexerror
for Asset Tag Capture
- Replaced @adamcodega's
apps
with @smithjw's policy_array
- Added progress update
- Added filepath validation
- Added initial "Welcome Screen" with Asset Tag Capture and Debug Mode