desktop_updater 1.4.0  desktop_updater: ^1.4.0 copied to clipboard
desktop_updater: ^1.4.0 copied to clipboard
Flutter desktop updater plugin supporting Windows, macOS, and Linux. It can download and install updates for your application from GitHub, GitLab, local file systems, and S3.
What is Desktop Updater? #
This Flutter plugin supports desktop platforms including macOS, Windows, and Linux. It enables in-app application updates without requiring users to re-download the entire application. The plugin applies updates by restarting the application, ensuring a seamless user experience. Additionally, it provides two essential commands for preparing updates efficiently.
How does it work? #
This plugin is a platform-specific solution that executes native code tailored to each supported platform. Additionally, it includes a built-in update interface that can be seamlessly integrated into your application.
Getting Started #
Add dependency to your pubspec.yaml:
dependencies:
  ...
  desktop_updater: ^1.0.2
Install as CLI, Run in your terminal:
dart pub global activate desktop_updater
Usage #
Add the following codes to your home page or any page you want to see the update card.
import 'package:desktop_updater/desktop_updater.dart';
late DesktopUpdaterController _desktopUpdaterController;
@override
void initState() {
    super.initState();
    _desktopUpdaterController = DesktopUpdaterController(
        appArchiveUrl: Uri.parse(
        "https://www.yoursite.com/app-archive.json",
        ),
    );
}
Then wrap your home page with DesktopUpdater widget, under the Scaffold widget.
@override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text("Your App Home Page"),
      ),
      body: DesktopUpdateWidget(
        controller: _desktopUpdaterController,
        child: Center(
            child: Column(
                mainAxisAlignment: MainAxisAlignment.center,
                children: <Widget>[
                    const Text(
                        'Hello World!',
                    ),
                ],
            ),
        ),
      ),
    );
}
there is also sliver for custom scroll view, you can use DesktopUpdateSliver widget.
@override
Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
        title: const Text("Your App Home Page"),
        ),
        body: CustomScrollView(
            slivers: <Widget>[
                DesktopUpdateSliver(
                    controller: _desktopUpdaterController,
                ),
                SliverList(
                    delegate: SliverChildListDelegate(
                    [
                        const Text(
                        'Hello World!',
                        ),
                    ],
                ),
            ],
        ),
    );
}
You can use this directly as a card for custom purposes. While you cannot modify the scaffold background in DesktopUpdateSliver or DesktopUpdateWidget, you can adjust colors and use it anywhere as needed
@override
Widget build(BuildContext context) {
    return Scaffold(
        backgroundColor: Colors.blue,
        appBar: AppBar(
        title: const Text("Plugin example app"),
        ),
        body: Padding(
        padding: const EdgeInsets.symmetric(horizontal: 16),
        child: Center(
            child: Column(
                children: [
                    Theme(
                        data: ThemeData(
                            colorScheme:
                                ColorScheme.fromSeed(seedColor: Colors.blue).copyWith(
                            onSurface: Theme.of(context).colorScheme.onSurface,
                            onSurfaceVariant:
                                Theme.of(context).colorScheme.onSurfaceVariant,
                            primary: Theme.of(context).colorScheme.primary,
                            surfaceContainerLowest:
                                Theme.of(context).colorScheme.surfaceContainerLowest,
                            surfaceContainerLow:
                                Theme.of(context).colorScheme.surfaceContainerLow,
                            surfaceContainerHighest:
                                Theme.of(context).colorScheme.surfaceContainerHighest,
                            ),
                        ),
                        child: DesktopUpdateDirectCard(
                            controller: _desktopUpdaterController,
                            child: const Text("This is a child widget"),
                        ),
                    ),
                    const Text(
                    "Running on: 1.0.0+1",
                    ),
                    Text("Running on: $_platformVersion\n"),
                ],
            ),
        ),
        ),
    );
}
You can use as alert dialog a with UpdateDialogListener:
@override
Widget build(BuildContext context) {
    return Scaffold(
    appBar: AppBar(
        title: const Text("Plugin example app"),
    ),
    body: Column(
        children: [
            /// This widget not rendering
            UpdateDialogListener(
                controller: _desktopUpdaterController,
            ),
        ],
    )
Creating app-archive.json #
{
    "appName": "Desktop Updater",
    "description": "This is my app description",
    "items": [
        {
            "version": "0.1.8",
            "shortVersion": 9,
            "changes": [
                {
                    "type": "chore",
                    "message": "Fix bug #1"
                },
                {
                    "type": "feat",
                    "message": "Add new feature #1"
                },
                {
                    "message": "Add new feature #2"
                }
            ],
            "date": "2025-01-10",
            "mandatory": true,
            "url": "https://www.yourwebsite.com/archive/desktop_updater/0.1.8%2B9-windows",
            "platform": "windows"
        },
        {
            "version": "0.1.7",
            "shortVersion": 8,
            "changes": [
                {
                    "type": "chore",
                    "message": "Fix bug #1"
                },
                {
                    "type": "feat",
                    "message": "Add new feature #1"
                },
                {
                    "message": "Add new feature #2"
                }
            ],
            "date": "2025-01-10",
            "mandatory": true,
            "url": ""https://www.yourwebsite.com/archive/desktop_updater/0.1.6%2B7-macos",
            "platform": "macos"
        }
    ]
}
How to use it? #
The steps are as follows:
- Prepare an app-archive file.
- Add a JSON file specifying the new version.
- Build the application using the CLI and generate the output.
- Upload the output directory, ensuring all its contents are accessible.
Commands #
You need to update version on pubspec.yaml file and run the following commands to build the application:
dart run desktop_updater:release macos
then it will create a folder named dist, then run the following command:
dart run desktop_updater:archive macos
You'll see 1.0.0+1-macos folder in dist/1 folder. You can upload this folder to your server directly as a folder, you'll have to access the folder directly. You can use s3 or your own server to host the files, you can also use github pages to host the files, but this should be public access.
App Archive JSON Structure #
You should add your versions to the items array. Each version should have the following fields:
- version: Required, The version number of the app.
- shortVersion: Required, The short version number of the app. This is used to compare the versions.
- changes: Required, The changes made in this version. This is an array of objects with the following fields:- type: Optional, the type of the change. This can be one of the following values: feat, fix, chore, docs, style, refactor, perf, test, build, ci, or other.
- message: Required, The message describing the change.
 
- date: Required, The date when this version was released.
- mandatory: Required, A boolean value indicating whether this version is mandatory. If this is true, the user will not be able to skip this version.
- url: Required, The URL where the app can be downloaded. This should be a direct link of the folder containing the app files.
- platform: Required, The platform for which this version is available. This can be one of the following values: windows, macos, or linux.
Customization #
You can change text and button text by passing DesktopUpdateLocalization to controller.
@override
void initState() {
    super.initState();
    _desktopUpdaterController = DesktopUpdaterController(
        appArchiveUrl: Uri.parse(
        "https://www.yoursite.com/app-archive.json",
        ),
        localization: const DesktopUpdateLocalization(
            updateAvailableText: "Update available",
            newVersionAvailableText: "{} {} is available",
            newVersionLongText:
                "New version is ready to download, click the button below to start downloading. This will download {} MB of data.",
            restartText: "Restart to update",
            warningTitleText: "Are you sure?",
            restartWarningText:
                "A restart is required to complete the update installation.\nAny unsaved changes will be lost. Would you like to restart now?",
            warningCancelText: "Not now",
            warningConfirmText: "Restart",
        ),
    );
}