Skip to content

Sparkle 2.0.0-beta.5

Pre-release
Pre-release
Compare
Choose a tag to compare
@Sparkle-Bot Sparkle-Bot released this 08 Nov 08:32
· 345 commits to 2.x since this release

Changes from Beta 4:

  • Revert "Set CODE_SIGN_INJECT_BASE_ENTITLEMENTS=NO for release (#1994)
  • Add safer handling for applying binary delta files (Zorg) (#1988)
  • Add <sparkle:fullReleaseNotesLink> element for showing users full release notes of an application (aONe) (#2001)
  • Add full release notes link flag to generate_appcast (Zorg) (#2015)
  • Add delegate method for showing full release notes inside the application (Billy Gray) (#1989)
  • Whitelist about:srcdoc as a safe web URL (Louis Pontoise , Zorg) (#2006)
  • Clarify documentation for canCheckForUpdates / sessionInProgress (Zorg) (#2009)
  • Fix null deference analyzer warnings (Zorg) (#2011)
  • Don't use current date unless necessary when scheduling next update (Zorg) (#1992)
  • Prevent potential rapid update checks using monotonic clock (Zorg) (#2002)

To simplify integration of Sparkle in sandboxed applications, the XPC Services were moved inside of Sparkle's framework in Beta 4.

If you use Sparkle's Delta Updates support, you must create new delta files using a relatively recent version of Sparkle 2 (#1906 - from July 24). Newly generated delta files will still be patchable from much older versions of Sparkle.

Please view Sparkle's updated guide on sandboxing if you use a custom workflow for signing your app outside of Xcode (Beta 5 made some changes here), or haven't adapted to the XPC Services being moved inside the framework yet from Beta 4.

For letting users browse your application's full version history, check out our updated documentation on our Publishing an update page.

Overall Changes:

  • Support for Sandboxed Applications (Zorg)
  • Support for writing custom user interfaces (Zorg)
  • Support for updating external Sparkle-based bundles (Zorg)
    • Added command line utility to update Sparkle-based bundles (Zorg)
  • More modern architecture
    • Moves extraction, validation, and installation into a submitted launchd agent/daemon with XPC communication (Zorg)
    • Features faster installs with shorter update/relaunch times (#1802) (Zorg)
    • Provides more robust installs that need to request user authorization (Zorg)
    • Adoption of atomic-safe bundle replacing updates leveraging APFS (#1801) (Zorg)
  • API Changes
    • Introduced new SPUStandardUpdaterController, SPUUpdater, SPUUserDriver classes/protocols (Zorg)
    • Decoupled AppKit and UI logic in the framework from core functionality (Zorg)
    • Ensure (most) API / ABI compatibility with Sparkle 1.x; you can likely test Sparkle 2 in an existing app without any changes (Zorg)
    • Deprecated SUUpdater, albeit it is still functional for testing and transitional purposes (Zorg)
    • -bestValidUpdateInAppcast:forUpdater: delegate method behavior has been refined and discouraged for some cases. Please review its updated header documentation in SPUUpdaterDelegate.h if you use this method. (#1838, #1862, #1879, #1880) (Zorg)
    • Delegation methods may have been removed or added to the newer updater API. Please review SPUUpdaterDelegate if using SPUUpdater. (Zorg)
  • Updater Changes
    • Automatic silent and manual update alert prompts are now merged together (Zorg)
    • Updates will attempt to install even if the user quits the application without relaunching the application update explicitly (Zorg)
    • Updates can be downloaded in the background automatically but later prompt the user to install them, particularly if Sparkle doesn't have sufficient permission to install them without the user's permission (Zorg)
    • Authorization now occurs before launching the installer and before terminating the application, which can be canceled by the user cleanly (Zorg)
    • Sparkle uses the icon of the bundle to update for its authorization dialog. A 32x32 image representation of the icon is needed. (Zorg)
    • Sudden termination for silent automatic updates isn't disabled anymore (Zorg)
  • Policy Changes
    • Package based updates that are zipped or archived must add sparkle:installationType="package" to the appcast item enclosure (this doesn't apply to bare packages that aren't archived) (Zorg)
    • We now recommend using sparkle:version and sparkle:shortVersionString top level elements instead of enclosure attributes (#1878) (Zorg)
    • The link element in an appcast item is now used for directing users to the product's website if they don't meet minimum system requirements (#1877) (Zorg)
  • Major/Paid Upgrades Enhancements
    • Latest minor updates are preferred over major updates (specified by sparkle:minimumAutoupdateVersion) (#1850) (Zorg)
    • Major updates can be skipped with a user confirmation (#1853) (Zorg)
  • Informational only and critical updates can be specified selectively by app version (#1862)
  • Expose why a new update is unavailable and direct user to prior release notes or website info (#1877, #1886) (Zorg)
    • Add sparkle:fullReleaseNotesLink element allowing Sparkle to show a better stylized and full changelog to the user (#2001) (aONe)
    • Add delegate API allowing applications to show full in-app or offline version history to the user (#1989) (Billy Gray)
  • Add support for posting updates only on specific channels (eg for supporting beta updates) (#1879) (Zorg)
  • System profiler privacy and transparency (#1690) (Martin Pilkington)
  • Support getting app icon from asset catalog (#1694) (Charles Srstka)
  • Don't hide update alert window now on deactivation (#1804) (Zorg)
  • Don't bring up authorization just because group ID doesn't match (#1830) (Zorg)
  • Raise minimum system version to 10.11 (Zorg)
  • Special thanks to developers using early builds of this release in production and contributors for keeping this running (Kornel, Jonas Zaugg, Gwynne Raskind, Jordan Rose, Tony Arnold, Bryan Jones, Christian Tietze, Jakob Egger, and many more)

Please visit Sparkle's website for more information on documentation and migration.

If you are migrating from earlier alpha versions of Sparkle 2, please re-familiarize yourself with the Sandboxing guide. Some of the XPC Services are now optional and integration with code signing has been simplified. The SPUUserDriver protocol for custom user interfaces has been greatly simplified too.