Skip to content

Latest commit

 

History

History
408 lines (374 loc) · 20.4 KB

CHANGELOG.md

File metadata and controls

408 lines (374 loc) · 20.4 KB

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

[2.2.0] - 2025-01-07

Changed

  • A slight background has been added increasing visaibility of the text.
  • Main window is now slightly resizeable to allow for window to be resized to a smaller size.
  • Last reboot time is now monitored and updated every 5 minutes. Displaying in minutes, hours or days depending on the time since last reboot.
  • Battery temperature will adapt to the configured measurement system in macOS and show temp in either Celsius or Fahrenheit.
  • Storage API has been changed for a more accurate reading of actual storage used.
  • "Is Admin" will now display "yes" or "no" localized instead of enabled or disabled.
  • In addition to only checking if Company Portal exists when dynamically setting the Mode to use, the server url will now also be checked. If the server url contains "i.manage.microsoft.com", the MDM will be set to Intune. This is because Company Portal can validly exist on a device without the device being managed by Intune.
  • Button labels on actions can now be set to a custom value. This allows for admins to set custom labels for actions that are displayed in the Self Service page. Example configuration:
<dict>
    <key>Command</key>
    <string>open https://github.com/macadmins/supportcompanion</string>
    <key>Description</key>
    <string/>
    <key>Icon</key>
    <string>heart.fill</string>
    <key>Name</key>
    <string>Open Intranet</string>
    <key>ButtonLabel</key>
    <string>Open</string>
</dict>

Fixed

  • Artifacts were being left behind on the desktop window when IP address was updated.

Added

  • The configured logo will now be displayed in the tray menu as well. Can be hidden by setting ShowLogoInTrayMenu to false in the configuration.
  • A new option to show the desktop information window "frosted". This allows for a frosted glass effect on the desktop information window. Example configuration:
<key>DesktopInfoBackgroundFrosted</key>
<true/>
  • A new option to show a custom view in the navigation bar based on a Markdown file. This allows for creating a custom view with custom information relevant to your organization. Example configuration:
<key>MarkdownFilePath</key>
<string>/path/to/custom/view.md</string>
<key>MarkdownMenuLabel</key>
<string>Custom View</string>
<key>MarkdownMenuIcon</key>
<string>doc.text</string>
  • A new option to show custom cards in the navigation bar. This allows for displaying large numbers of cards without cluttering the home view, by moving them to their own view. Example configuration:
<key>CustomCardsMenuLabel</key>
<string>Custom Cards</string>
<key>CustomCardsMenuIcon</key>
<string>doc.text</string>
<key>CustomCardPath</key>
<string>/path/to/custom/cards.json</string>
  • A new option to trigger actions using the CLI. This allows for triggering actions using the CLI instead of the UI. This can be useful for automating actions or triggering actions from a script. By default, actions configured as privileged will require authentication. This can be disabled by setting RequirePrivilegedActionAuthentication to false. Example usage:
/Applications/SupportCompanion.app/Contents/Resources/SupportCompanionCLI action "Restart clipboard"
  • Additional arguments to the CLI to allow for getting additional information that is displayed in the app. Example usage:
/Applications/SupportCompanion.app/Contents/Resources/SupportCompanionCLI battery

Example output:

🔋 Battery Information
-----------------------
Health:          93% 🔋
Cycle Count:     37
Temperature:     36.7°C 🌡️
Charging Status: Not Charging
Time Remaining:  N/A
  • A new feature that allows for user elevation of standard users to admin users. This feature is useful for instances where a user needs to perform an action that requires admin rights. The user can request elevation by clicking the Elevate button in the tray menu or Identity menu. The admin can configure wether a reason is required, how long the reason must be and if the reason should be sent via a webhook to a specified URL or saved to disk. Example configuration:
<key>EnableElevation</key>
<true/>
<key>RequireResonForElevation</key>
<true/>
<key>ReasonMinLength</key>
<integer>20</integer>
<key>MaxElevationTime</key>
<integer>60</integer>
<key>ElevationWebhookUrl</key>
<string>https://webhook.url</string>
<key>ShowElevateTrayCard</key>
<true/>
<key>ElevationSeverity</key>
<integer>6</integer>

Example of JSON payload sent to webhook:

{
  "severity" : 6,
  "date" : "2024-12-16T11:21:01Z",
  "host" : "Tobias's MacBook",
  "user" : "tobias",
  "serial" : "H123456789",
  "reason" : "Awesome dev stuff"
}

[2.1.0] - 2024-12-11

Changed

  • The tray menu has been changed to a custom menu that is an extension of the apps main UI. This allows for a more consistent look and feel between the tray menu and the main app. The tray menu now displays the same information as the main app, including device information, storage information and patching progress as well as actions. If you have custom actions configured using Actions, the first 6 actions will be displayed in the tray menu. If you have more than 6 actions, the rest can be run from the Self Service section in the main app.
  • If the app is launched using the URL scheme supportcompanion://, the tray menu will not be displayed.
  • Shadow for green text has been removed as it could make the text look blurry. Instead the green has been changed to a darker shade to make it more readable.
  • Copy device info button will now include additional information about the device, including battery and storage. Example output:
--------------------- Device --------------------- 
Host Name: AwesomeMac
Serial Number: C0123456789
Model: MacBook Pro (14-inch, Nov 2023)
Processor: Apple M3 Pro
Memory: 36 GB
OS Version: 15.2.0
OS Build: 24C98
IP Address: 192.168.68.108
Last Reboot: 4 days
--------------------- Battery --------------------- 
Health: 94%
Cycle Count: 35
Temperature: 34.5°C
--------------------- Storage --------------------- 
Used: 74.9%
FileVault: Enabled

Added

  • Support for Japansese localization, thanks @kenchan0130 for the Japanese localization
  • A badge to the tray menu icon that visually indicates that the user has pending updates to install.

[2.0.2] - 2024-12-06

Changed

  • Added a softer shade of orange and red when light mode is enabled to improve visibility and readability.
  • If launching the app using a URL scheme, the app will now exit only when supportcompanion:// is used. This allows for the app to be started using a URL scheme and remain open when using supportcompanion://home or similar. Example:

Will exit when the window is closed:

open supportcompanion://

Will remain open when the window is closed:

open supportcompanion://home

Added

  • Option to hide Categories and Dividers on the Desktop Info view. This allows for a cleaner and more focused view of the information displayed. Example configuration:
<key>DesktopInfoHideItems</key>
<array>
    <string>Category</string>
    <string>Divider</string>
</array>

[2.0.1] - 2024-12-05

Changed

  • Added a preinstall script that will uninstall version 1.X if found.

[2.0.0] - 2024-12-02

AKA the Swift Update

Changed

  • The entire project has been migrated from C# and AvaloniaUI/SukiUI to Swift and SwiftUI, bringing significant improvements:

    • A more responsive and fluid user interface.
    • A native macOS look and feel for a seamless experience.
    • Superior memory management and overall performance enhancements.
  • The following configurations and identifiers have changed:

    • Bundle ID: Updated, requiring the uninstallation of version 1.x before installing 2.0.
    • Icons: Redesigned for better alignment with macOS standards.
    • Configuration Keys: Some keys have been deprecated or updated.

Deprecated

The following configuration keys have been removed:

  • BrandColor
  • HiddenWidgets
  • CustomColors
  • IntuneMode
  • ShowMenuToggle
  • DesktopInfoCustomItems
  • DesktopInfoBackgroundColor
  • DesktopInfoColorHighlight
  • CustomWidgetsPath
  • SystemProfilerApps

Updated

  • DesktopInfoLevel:
    • Previously a string, now an integer.
    • Removed string values: Minimal, Hardware, Full, Custom.
    • Added numeric levels: 1-5.

Notes

  • A clean uninstall of version 1.x is required before installing 2.0. Use the script located at:
    /Applications/Utilities/SupportCompanion.app/Contents/Resources/Uninstall.sh
    For additional migration information, refer to the migration guide.

[1.4.0] - 2024-11-06

Changed

  • Avalonia and SukiUI has been updated.
  • As part of the SukiUI update, the SukiHost has been updated to use the new scalable style of hosts.
  • Mainwindow height has been slightly increased.
  • Uninstall script updated with a check for root and use of Apple best practices. #50 thanks @pboushy

Fixed

  • When a app or system update notification was clicked, the command was not run resulting in nothing happening.
  • ToolTips were not being shown.

[1.3.0] - 2024-09-19

Added

  • A new mode for the app called SystemProfilerApps which allows for the app to display applications installed under /Applications and their version numbers as well as Architecture. This mode is useful for admins who want to see what applications are installed on the device and their version numbers. To enable this mode, set SystemProfilerApps to true in the configuration. Example configuration:
<key>SystemProfilerApps</key>
<true/>
  • A new page called Self Service that will display all actions configured by an admin in the mobileconfig using the Actions array. This allows for easy access to self-service actions that the user can perform on their device. If no actions are configured, the page will not be displayed.
  • A new key for configuring an icon for actions that will be displayed in the Self Service page. This allows for admins to configure an icon for each action that is displayed in the Self Service page. The icon should be a material icon name from https://pictogrammers.com/library/mdi/. For example apple-finder would be AppleFinder. Example configuration:
<key>Actions</key>
<array>
    <dict>
        <key>Name</key>
        <string>Restart clipboard</string>
        <key>Command</key>
        <string>killall pboard</string>
        <key>Icon</key>
        <string>AppleFinder</string>
    </dict>

Changed

  • If a widget is configured to not be shown or otherwise should not be shown, the widget will now be blanked out instead of being hidden. This is to ensure that the layout of the widgets is consistent and that the user knows that the widget is not available.

[1.2.0] - 2024-09-04

Added

  • German localization, thanks @motodotsh for the German localization
  • A new suite package that contains the main app and the LaunchAgent package. This allows for admins to install both the main app and the LaunchAgent using a single package
  • A new option to use custom widgets on the Home view of the app. This allows for admins to add custom widgets to the Home view of the app to display information that is relevant to the user. This is done by using a JSON file populated any way the admin sees fit. To add custom widgets, add the below key to the mobileconfig and configure a JSON like the below example
<key>CustomWidgetsPath</key>
<string>/path/to/custom/widgets.json</string>
[
  {
    "icon": "Laptop",
    "header": "Custom Widget",
    "data": {
      "Custom Label1": "A long example of a custom value with word wrap",
      "Custom Label2": "Custom Value2"
    }
  }
]

Changed

  • Updated the LaunchAgent to launch the process using ProcessType Interactive as the UI was sluggish when launched as a background process
  • Tray Icon is now a outlined version of the logo to make it look more native on macOS. It's also a macOS template image which means it will change color based on the user's wallpaper
  • Avalonia has been updated to 11.1.3

[1.1.0] - 2024-06-24

Added

  • A package for a LaunchAgent which is signed and notarized using the same certificate as the main app
    • The LaunchAgent is configured to run the app at login, when activated and also start the app if closed by the user
  • An option to disable all notifications, to disable notifications, set the value for NotificationInterval to 0
  • A new feature to show information about the device and support contact information on the desktop background. This allows for admins to show information about the device and support contact information on the desktop background. The information is displayed in any corner of the desktop background and can be customized using the configuration. Example configuration:
<key>ShowDesktopInfo</key>
<true/>
<key>DesktopInfoFontSize</key>
<integer>19</integer>
<key>DesktopInfoLevel</key>
<string>Custom</string>
<key>DesktopInfoCustomItems</key>
<array>
    <string>HostName</string>
    <string>SerialNumber</string>
    <string>SupportEmail</string>
</array>
<key>DesktopInfoBackgroundColor</key>
<string>#000000</string>
<key>DesktopInfoBackgroundOpacity</key>
<real>0.6</real>
<key>DesktopInfoColorHighlight</key>
<false/>
<key>DesktopPosition</key>
<string>BottomRight</string>

Changed

  • Line breaks and white space is removed when BrandLogo is parsed as a base64 string to ensure that the logo is displayed correctly in the side menu
  • Post-install script now re-launches the app after the installation is complete to ensure that the app is running with the latest version

Fixed

  • AD Password Expiry color was not being set correctly in the UI. This has been fixed by setting the color based on the number of days until the password expires

[1.0.7] - 2024-06-19

Added

  • A package for the LaunchAgent which is signed and notarized using the same certificate as the main app
  • An option to disable all notifications, the disable notifications set the value for NotificationInterval to 0
  • The option to show information about the device and support contact information on the desktop background. This allows for admins to show information about the device and support contact information on the desktop background. The information is displayed in any corner of the desktop background and can be customized using the configuration. Example configuration:
<key>ShowDesktopInfo</key>
<true/>
<key>FontSize</key>
<integer>19</integer>
<key>DesktopInfoLevel</key>
<string>Custom</string>
<key>DesktopInfoCustomItems</key>
<array>
    <string>HostName</string>
    <string>SerialNumber</string>
    <string>SupportEmail</string>
</array>
<key>DesktopInfoBackgroundColor</key>
<string>#000000</string>
<key>DesktopInfoBackgroundOpacity</key>
<real>0.6</real>
<key>DesktopInfoColorHighlight</key>
<false/>
<key>DesktopPosition</key>
<string>BottomRight</string>

Changed

  • Line breaks and white space is removed when BrandLogo is parsed as a base64 string to ensure that the logo is displayed correctly in the side menu
  • Post-install script now re-launches the app after the installation is complete to ensure that the app is running with the latest version

Fixed

  • AD Password Expiry color was not being set correctly in the UI. This has been fixed by setting the color based on the number of days until the password expires

[1.0.6] - 2024-06-17

Fixed

  • Not configuring the BrandLogo in the configuration would cause the app to crash on startup. This has been fixed by adding a check to see if the BrandLogo is configured before trying to load it

[1.0.5] - 2024-06-10

Added

  • Added a new configuration to disable the menu toggle button in the app. This allows for admins to disable the menu toggle button if they want to prevent users from hiding the menu. Example configuration: #38
<key>ShowMenuToggle</key>
<false/>
  • Option to start the app using a URL scheme. This allows for admins to start the app using a URL scheme, which can be useful for starting the app from a script or another app. The URL scheme is supportcompanion://home. When started using the URL scheme, the app will exit when the window is closed instead of running in the background #36
  • Option to provide the BrandLogo as a base64 string in the configuration. This allows for admins to provide the BrandLogo as a base64 string in the configuration instead of a local path. This can be useful for providing the logo as part of a configuration profile. Example configuration:
<key>BrandLogo</key>
<string>{BASE64 STRING}</string>
  • Norwegian localization, thanks @johnhans for the Norwegian localization

Changed

  • Margins around BrandLogo has been increased to make it look better in the side menu

Fixed

  • The BrandName was always displayed in white text in the side menu, which made it hard to read if light mode was enabled. Text color property has been removed to ensure it is set dynamically based on the user's system preferences #39

[1.0.4] - 2024-05-31

Added

  • Localized the app to Swedish and French. The app will now display in the user's preferred language if it is set to one of these languages in macOS. If the user's preferred language is not one of these, the app will default to English. Thank you, @hachirotahoshino, for the French localization #31
  • New configuration key to allow for adding a company logo to the side menu of the app. This allows for admins to add their company logo to the app to make it more personalized. Example configuration:
<key>BrandLogo</key>
<key>/local/path/to/logo.png</key>

Changed

  • Pending apps tooltip in Intune mode now adds the application name to the tooltip to make it easier to see which apps are pending if they have long names #30
  • Tray icon has been changed to a monochrome version #34
  • Emojis removed from tray menu to conform to Apple design guidelines 🥺 #34
  • Email address in the support info dialog now has a mailto: link to make it easier for users to contact support
    • As it is a link, the color of the email address has been changed to blue to indicate that it is clickable

Fixed

  • Identity view crashed the app if Kerberos SSO information failed to be retrieved. This has been fixed by using a TryGetValue on the dictionary to avoid a crash if the key is not present #28
  • Email address in the support info dialog did not display the entire email address if it was too long. This has been fixed by adding a word wrap #29

[1.0.3] - 2024-05-28

Fixed

  • Notification Interval failed to be cast as an integer, causing the app to crash on initialization. The value is now converted from NSNumber to Int before being used in the app.

[1.0.2] - 2024-05-27

Changed

  • Changed the configuration of the custom tray menu actions to use Name and Command keys for better readability.

Fixed

  • The Munki update percentage was not being updated correctly in the UI as apps were updated.

[1.0.1] - 2024-05-27

Added

  • Added a new configuration option to allow for adding custom actions to the tray menu. This allows for admins to add custom actions to the tray menu for common tasks that the user might perform for support purposes, such as restarting a service or running a script. Example configuration:
<key>Actions</key>
<array>
    <dict>
        <key>Restart clipboard 🥹</key>
        <string>killall pboard</string>
    </dict>
    <dict>
        <key>Restart Intune Agent ⚡️</key>
        <string>/usr/bin/osascript -e 'do shell script \"sudo killall IntuneMdmAgent\" with administrator privileges'</string>
    </dict>
</array>

[1.0.0] - 2024-05-25

This is the first production release of Support Companion! 🎉