Skip to content

Quick and easy installer and automatic updates for desktop applications

License

Notifications You must be signed in to change notification settings

luislhg/Clowd.Squirrel

 
 

Repository files navigation

Nuget Nuget (with prereleases) Discord Build

Clowd.Squirrel

Squirrel is both a set of tools and a library, to completely manage both installation and updating your desktop application.

Feel free to join our discord to recieve updates or to ask questions:

discordimg2


Looking for info on v3.0 / cross-platform?

Clowd.Squirrel v3.0 is a ground-up re-write and now supports macos (linux in the future?). Documentation for this is very limited but I have started working on this in the docs-v3 folder. This work is being done in the develop branch.

I will continue to support 2.x with critical fixes until further notice. This is currently the master branch.


What Do We Want?

Apps should be as fast easy to install. Update should be seamless like Google Chrome. From a developer's side, it should be really straightforward to create an installer for my app, and publish updates to it, without having to jump through insane hoops.

  • Integrating an app to use Squirrel should be extremely easy, provide a client API, and be developer friendly.
  • Packaging is really easy, can be automated, and supports delta update packages.
  • Distributing should be straightforward, use simple HTTP updates, and provide multiple "channels" (a-la Chrome Dev/Beta/Release).
  • Installing is Wizard-Free™, with no UAC dialogs, does not require reboot, and is .NET Framework friendly.
  • Updating is in the background, doesn't interrupt the user, and does not require a reboot.

Migrating from Squirrel.Windows?

  • The command line interface for Squirrel.exe is different. Check 'Squirrel.exe -h' for more info.
  • The command line for Update.exe here is compatible with the old Squirrel.
  • Update.exe here is bigger and is included in your packages. This means Update.exe will be updated each time you update your app. As long as you build delta packages, this will not impact the size of your updates.
  • Migrating to this library is fully compatible, except for the way we detect SquirrelAware binaries. Follow the Quick Start guide.
  • There have been a great many other improvements here. To see some of them have a look at the feature matrix.
  • Something detected as a virus? This was an issue at the old Squirrel, and also see issue #28

Quick Start For .NET Apps

  1. Install the Clowd.Squirrel Nuget Package

  2. Add SquirrelAwareVersion to your assembly manifest to indicate that your exe supports Squirrel. Note: In newer .NET Core versions you first need to add the Application Manifest through New Item window.

    <?xml version="1.0" encoding="utf-8"?>
    <assembly manifestVersion="1.0" xmlns="urn:schemas-microsoft-com:asm.v1">
      <SquirrelAwareVersion xmlns="urn:schema-squirrel-com:asm.v1">1</SquirrelAwareVersion>
    </assembly>
  3. Handle Squirrel events somewhere very early in your application startup (such as the beginning of main() or Application.OnStartup() for WPF).

    public static void Main(string[] args)
    {
        // run Squirrel first, as the app may exit after these run
        SquirrelAwareApp.HandleEvents(
            onInitialInstall: OnAppInstall,
            onAppUninstall: OnAppUninstall,
            onEveryRun: OnAppRun);
    
        // ... other app init code after ...
    }
    
    private static void OnAppInstall(SemanticVersion version, IAppTools tools)
    {
        tools.CreateShortcutForThisExe(ShortcutLocation.StartMenu | ShortcutLocation.Desktop);
    }
    
    private static void OnAppUninstall(SemanticVersion version, IAppTools tools)
    {
        tools.RemoveShortcutForThisExe(ShortcutLocation.StartMenu | ShortcutLocation.Desktop);
    }
    
    private static void OnAppRun(SemanticVersion version, IAppTools tools, bool firstRun)
    {
        tools.SetProcessAppUserModelId();
        // show a welcome message when the app is first installed
        if (firstRun) MessageBox.Show("Thanks for installing my application!");
    }

    When installed, uninstalled or updated, these methods will be executed, giving your app a chance to add or remove application shortcuts or perform other tasks. You should not update your app from the hooks.

  4. Build/Publish your app (with msbuild, dotnet publish or similar)

  5. Create a Squirrel release using the Squirrel.exe command line tool. The tool can be downloaded from GitHub Releases, and it is also bundled into the Clowd.Squirrel nuget package. If installed through NuGet, the tools can usually be found at:

    • %userprofile%\.nuget\packages\clowd.squirrel\2.9.40\tools, or;
    • ..\packages\clowd.squirrel\2.9.40\tools

    Once you have located the tools folder, create a release. Minimal example below with some useful options, but explore Squirrel.exe -h for a complete list.

    Squirrel.exe pack --packId "YourApp" --packVersion "1.0.0" --packDirectory "path-to/publish/folder"

    Important Notes:

    • The same --releaseDir (default .\Releases if not specified) should be used each time, so delta updates can be generated.
    • The package version must comply to strict 3-part SemVer syntax. (eg. 1.0.0, 1.0.1-pre)
    • A list of supported runtimes for the --framework argument is available here
  6. Distribute your entire --releaseDir folder online. This folder can be hosted on any static web/file server, Amazon S3, BackBlaze B2, or even via GitHub Releases.

    If using CI to deploy releases, you can use the package syncing commands to download the currently live version, before creating a package. This means delta/patch updates can be generated. Complete powershell example:

    # build / publish your app
    dotnet publish -c Release -o ".\publish" 
    
    # find Squirrel.exe path and add an alias
    Set-Alias Squirrel ($env:USERPROFILE + "\.nuget\packages\clowd.squirrel\2.9.40\tools\Squirrel.exe");
    
    # download currently live version
    Squirrel http-down --url "https://the.place/you-host/updates"
    
    # build new version and delta updates.
    Squirrel pack`
     --framework net6,vcredist143-x86`  # Install .NET 6.0 (x64) and vcredist143 (x86) during setup, if not installed
     --packId "YourApp"`                # Application / package name
     --packVersion "1.0.0"`             # Version to build. Should be supplied by your CI
     --packAuthors "YourCompany"`       # Your name, or your company name
     --packDir ".\publish"`       # The directory the application was published to
     --icon "mySetupIcon.ico"`     # Icon for Setup.exe and Update.exe
     --splashImage "install.gif"        # The splash artwork (or animation) to be shown during install
  7. Update your app on startup / periodically with UpdateManager.

    private static async Task UpdateMyApp()
    {
       using var mgr = new UpdateManager("https://the.place/you-host/updates");
       var newVersion = await mgr.UpdateApp();
       
       // optionally restart the app automatically, or ask the user if/when they want to restart
       if (newVersion != null) {
          UpdateManager.RestartApp();
       }
    }

Feature Matrix

Feature Clowd.Squirrel Squirrel.Windows
Continuous updates, bug fixes, and other improvements
Provides a command line update interface (Update.exe) with your app
Update.exe Size ❌ 12.5mb ✅ 2mb
Provides a C# SDK netstandard2.0
net461
net5.0
net6.0
netstandard2.0
SDK has 100% XML comment coverage in Nuget Pacakge None, does not ship comments in NuGet
SDK Dependencies SharpCompress SharpCompress (outdated & security vulnerability)
NuGet (outdated and bugs)
Mono.Cecil (outdated and bugs)
Microsoft.Web.Xdt
Microsoft.CSharp
Microsoft.Win32.Registry
System.Drawing.Common
System.Net.Http
System.Web
SDK is strong-name signed
Provides an update package builder (Squirrel.exe)
Supports building tiny delta updates
Can compile a release/setup in a single easy command
Command line tool for package building that actually prints helpful messages to the console
CLI help text that is command-based and easily understandable
Supports building packages for native apps
Supports building packages for .Net/Core Limited/Buggy
Supports building packages for PublishSingleFile apps
Supports fully automated CI package deployments easily
Compiles an installer (Setup.exe)
Setup Splash Gif
Setup Splash Png,Jpeg,Tiff,Etc
Setup Splash Progress Bar
Setup Splash has Multi-Monitor DPI support
No internal dependencies on external frameworks/runtimes
Can deploy an application that has no dependencies ❌ (always installs .Net Framework with your app)
Can install .Net Full Framework during setup
Can install .Net/Core during setup
Can install vcredist during setup
Can install new runtimes (see above) during updates
Cleans up after itself Leaves huge log files everywhere
Does not delete itself during uninstall
Can build an MSI enterprise machine-wide deployment tool

Building Squirrel

For the impatient:

git clone https://github.com/clowd/Clowd.Squirrel
cd clowd/Clowd.Squirrel
build.cmd

See Contributing for additional information on building and contributing to Squirrel.

License and Usage

See COPYING for details on copyright and usage.

About

Quick and easy installer and automatic updates for desktop applications

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C# 64.3%
  • C++ 19.5%
  • C 16.1%
  • Other 0.1%