Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Table of Contents

Introduction

This wiki details the different ways to provide the app updates to the end-user and there pros and cons and finally conclude on the approach

Approach 1 - New installer


In this approach, we will provide the latest version of the app to the end-user then he needs to install with the new app which will be as follow

...

  1. User need to update the app manually 
  2. Can't provide force update
  3. Can override new version of the app with the old one
  4. User should know that new update available which requires communication to the user


Approach 2 - Electron auto-updater

Here app updates are provided using electron builder by building the app with publishing flag which will generate metadata to check for the update here we need to add electron-updater as a dependency require to code for to check and install the update

...

  1. Can provide force update 
  2. Comes out of the box
  3. Code signature validation not only on macOS but also on Windows.
  4. All required metadata files and artifacts are produced automatically.
  5. Download progress and staged rollouts supported on all supported platforms.
  6. It provides logs for the app update

Cons

  1. Doesn't work in Ubuntu  OS
  2. No granular control

Approach 3 - Custom Update

Here we will provide the app update in signed zip format which will be downloaded and install in the app which requires development to check for the update and install the update

...

  1. Development effort (Managing the update versions)
  2. Reliability needs to be proven
  3. UI to show update and check for updates
  4. It needs the packaging structure 
  5. Code required to push and pull the updates

Conclusion


Based on the above we will provide an app update with approach 1 which is providing a new installer for app update currently then we will move onto providing updates with approach 3 where we have control to update the app.

...