Technology
Publishing Updates
Release Workflow
- Standalone binaries are published as
Spacedrive-{Format}-{Target Triple}.zip - Updater binaries are published as
Spacedrive-Updater-{Target Triple}.zip
Desktop Update API
- Available at
/api/releases/tauri/[version]/[target]/[arch] - Version should be specified via
[version]or overridden inX-Spacedrive-Version- Exact versions should be specified as semantic versions, eg
0.1.0,1.0.0-alpha.1 - Release channels
stableandalphacan also be specifiedalphawill look for tags that contain the stringalphastablewill look for the release marked asLatest Release
- Exact versions should be specified as semantic versions, eg
- Looks for assets named
Spacedrive-Updater-{Target}-{Arch}.{Extension}Target:darwin,linux,windowsArch:x86_64,aarch64
- Returns
TauriResponse
Desktop Download API
- Available at
/api/releases/desktop/[version]/[target]/[arch] - Same version semantics as Desktop Update API
- Looks for assets starting with
Spacedrive-{Target}-{Arch}to allow for extensions like.dmg,.AppImageand.msi - Returns a redirect as it's intended to be invoked via
<a>elements
Publishing a Release
- Create tag that follows semver, eg.
0.1.0,1.0.0-alpha.1 - Update version number in
apps/desktop/src-tauri/Cargo.toml - Create release - name does not matter, only the tag
- Add assets that match the names expected by the Desktop Updater and Downloader APIs
- Publish release :)
