TL;DR This post proposes rewriting KopiaUI in Go and getting rid of Electron-based app, this is good for security, but may change how the UI behaves, your feedback is appreciated
Background
KopiaUI (the desktop application) is a small, yet quite complex application. It has very minimal user interface (tray menu), but to present the repository UI, it uses Electron - very large and complex technology stack with many dependencies.
This complexity makes it hard to secure against OSS supply-chain attacks. This post proposes rewriting the app using different technology, to make it smaller, easier to secure and hopefully easier to work with going forward.
Issues
-
KopiaUI has many dependencies (currently ~1170) on open-source NPM packages. The NPM ecosystem is notoriously hard to secure because of its complexity and there have been recent attacks on low-level NPM packages used by many, which wreaked havoc across OSS projects that had dependency on them. Kopia luckily wasn’t affected but it’s a matter of time before the next attack like this and it could affect us too.
-
Electron is huge (around 80-100 MB compressed, up to 500 MB on disk) because it embeds the entire Chromium browser so downloads are necessarily going to be that big, even if KopiaUI does not have that much code by itself.
-
Kopia UI is written in Javascript which is not the primary language for the project, as most of Kopia is written in Go
Proposed change
We will replace Electron app with a small Go app with minimal dependencies, which sits in the system tray and leverages web browser for the UI.
Since the underlying HTML UI is ultimately served by kopia server
and not KopiaUI
, we can use a web browser that the user already has installed: when one opens a repository window, the new KopiaUI will launch a browser window pointing at http://localhost:some-port
in a default web browser (Safari, Edge, Chrome, etc.) and present exactly the same UI as today.
Impact of the change
- [+] since the app will be written in Go, we will eliminate all NPM security concerns
- [+] this should reduce the build time by ~10 minutes
- [+] the KopiaUI app download will be much smaller (hopefully <20MB, installed size should be <50MB).
- [+] we’ll have better testing for the app logic
- [-] we will need to develop custom code signing and release pipeline (currently handled by electron-builder from NPM), this will take some time to get right.
- [+/?] we will need to develop custom auto-update support (also handled by electron-builder). This could actually open up smoother auto-update experience, because KopiaUI app will likely not need to be updated much, so updates can bring in just
kopia
- [+] KopiaUI will download the latest
kopia
on first run and keep it up-to-date. - [?] the repository windows will be part of a web browser app and not KopiaUI app. This should be very minor impact, since the KopiaUI app does not have any UI of its own beyond the Tray menu.
- [?] some are not possible in a browser (such as local directory selector) and will have to be emulated - this will likely add things like path autocompletion, so is probably a good thing.
Timeline
In terms of a timeline, I’m hoping to have a preview of this app as a separate download in v0.10 (we will still have Electron as a main option) in early 2022. Once the app is on par with current KopiaUI v0.11 will have it as the only UI option.
If there’s significant interest in keeping Electron mode, we can move it to separate repository and maintain there, but old KopiaUI won’t be part of official kopia builds past v0.11.
Feedback
We appreciate your feedback. Since it appears that majority of Kopia users rely on the UI, I’m curious what you think about this change and it might impact you.
Also, any help is appreciated, we’re always looking for folks to contribute to the project, since this is quite a major effort, we can accelerate it with external contributors.