JUSTInstaller 0.0.3

dotnet add package JUSTInstaller --version 0.0.3                
NuGet\Install-Package JUSTInstaller -Version 0.0.3                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="JUSTInstaller" Version="0.0.3" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add JUSTInstaller --version 0.0.3                
#r "nuget: JUSTInstaller, 0.0.3"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install JUSTInstaller as a Cake Addin
#addin nuget:?package=JUSTInstaller&version=0.0.3

// Install JUSTInstaller as a Cake Tool
#tool nuget:?package=JUSTInstaller&version=0.0.3                

J.ust U.nzip S.ome T.hings

Cross platform installer that values sipmlicity.

Options

  • EntryPoint
    The name of the executable or script that starts the application. Should not include the install path. On Windows '.exe' will be appended if necessary.

  • InstallBasePath / InstallFolderTemplate Where on the filesystem you want the application to be installed. For example { InstallBasePath=~/.apps/myapp/, InstallFolderTemplate=myApp_{version}} { InstallBasePath=c:\program files\MyApp, InstallFolderTemplate=/MyApp_v{version} }

  • CurrentVersionUri
    This is how we check for updates. Send a GET request to the given URI and get back the result text. (This is probably just a file on your webserver.) Assume the first line of the result is a version number and parse it. Compare against the current version. If the downloaded file is larger get that version from the UpdateLocationTemplate.
    For example: If we are currently on version 1.0 and CurrentVersionUri is http://mydomain.com/myapp/version.txt and the first line of version.txt is "1.1" we need to update so use "1.1" as the {version} in the UpdateLocationTemplate and download that to the InstallPathTemplate and update any links.

  • UpdateLocationTemplate
    Where to get the new files when an update is needed. Example: http://mydomain.com/myapp/downloads/{{version}}.zip

  • CurrentVersion
    If you don't want to use the version from the project file you can override it here.

  • KeepVersion (not implemented) Keep this many previous versions to allow quick roll back.

  • WindowsShortcutPaths Shortcuts (.lnk) to the application entrypoint. These will be updated when a new version is installed. If the installer is running on a non-Windows platform these are ignored.

  • SymlinksPaths Symlinks to the application entrypoint. These will be updated when a new version is installed.

  • SettingsPath If you use IsfirstRunOnCurrentVersion we need to create a current_version.txt file and we'll store it in this location. If this is not provided we use InstallBasePath/settings

Quick Start

using JUSTInstaller;
var installer = new Installer(new InstallerConfig(
        EntryPoint: "InstallMe",
        InstallBasePath: "~/apps/install_me",
        InstallFolderTemplate: "version_{version}",
        CurrentVersionUri: new Uri("http://digitalsorcery.net/InstallMe/version.txt"),
        UpdateLocationTemplate: "http://digitalsorcery.net/InstallMe/download/InstallMe_{version}.zip",
        WindowsShortcutPaths: new[] {
            Path.Combine(Environment.GetFolderPath(SpecialFolder.Desktop), "InstallMe")
        });
if (await installer.CheckForUpdate()) {
    // Setting run:true will automatically spawn the newly installed version. If you prefer to lauanch it yourself Process.Start(result.EntryPoint)
    var result = await installer.InstallUpdate(run: true);
    if (result != null) {
        Console.WriteLine($"Installed new version {result.Version}. Installed to {result.EntryPoint}");
        Application.Exit();
    }
}

Recipes / FAQ

I want to install on multiple platforms!

Sure! When you name your archives append a platform specific suffix. Then configure your installer with the same version URI and detect the current platform when setting your download URI.

var platform = System.Environment.OSVersion.Platform switch {
            PlatformID.Unix => "nix",
            PlatformID.Win32NT => "win",
        };
config.UpdateLocationTemplate = $"https://example.com/downloads/myapp_{{version}}_{platform}";

How do I set the current version for my application?

Set <Version>1.2.3</Version> in your csproj or supply it as a build parameter with /p:Version=1.2.3

What if the version of my application doesn't match the version from my {CurrentVersionUri}?

If your version is lower than {CurrentVersionUri} the application will always try to update. If your version is equal or higher it will never update.

It can! You just have to tell it where that is.

I changed my shortcuts and I need this version to remove the old shortcut location

No built in support but you can check IsfirstRunOnCurrentVersion and do some custom cleanup.

I use the registry to run my application on startup. When I install a new version I need to update the registry.

When you call InstallUpdate() and it installs a new version it will return an "entry point" which is the path to the new executable. You can use this to update to the new location. You could also use IsFirstRunOnCurrentVersion to check on startup if you need to do some cleanup.

I'd like my application to install into a priveledged location like c:/program files/

First, it's probably easier to just install per-user. However, if you want to you can accomplish this one of two ways.

  1. Using application manifests which require elevated priveledges. <requestedExecutionLevel level="requireAdministrator" uiAccess="false" />. As a warning, this functionality isn't uniformly supported cross platform.

  2. When Installer.CheckForUpdate() returns true spawn a separate process under platform specific elelvation. Have that process call the installer to do the update.

Does JUSTinstaller support uninstall?

Not currently.

How does IsfirstRunOnCurrentVersion work?

When you call IsfirstRunOnCurrentVersion it will check for a settings file named current_version.txt. If it doesn't exist or if the version number in that file is not the same as the CurrentVersion it will return true and update current_version.txt to have the currently running version. No file is created if you never check IsfirstRunOnCurrentVersion.

Design Notes

  • The installed application is an unziped zip file into {InstallBaesPath}/{InstallFolderTemplate}.
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.0.3 268 2/15/2023
0.0.2 385 10/28/2022
0.0.1 426 10/10/2022